广告
返回顶部
首页 > 资讯 > 后端开发 > Python >java中几种常见的排序算法总结
  • 829
分享到

java中几种常见的排序算法总结

2024-04-02 19:04:59 829人浏览 八月长安

Python 官方文档:入门教程 => 点击学习

摘要

目录本节目标;【插入排序】【优化版】【希尔排序】【选择排序】【堆排序】 【冒泡排序】介绍一个冒泡排序的优化方法; 【快速排序】【归并排序】【正文】【代码简介;】&

本节目标;

:分析常见的比较排序算法基本原理及实现

:分析排序算法的性能分析

:分析Java中常用排序方法

1 排序

       排序,就是使一串记录,按照其中某个或某些关键字的大小,递增或递减排列的操作。

平时的上下文中,提到排序 通常指排升序。

2 稳定性

     两个相同的数据,如果经过排序后,排序算法能保证其相对位置不发生变化,则称该算法具备稳定发行。

【插入排序】

在这里插入图片描述

【优化版】

  分析步骤;

第一步;将第一个元素下标设置为 i ,设 index  与 i 指向同一个元素

第二部 设置循环 利用 j  循环找出除 第一个元素以为最小的元素 将其交到index下

第三步 将index 与 第一个元素交换

 public static void insertSort(int[] array) {
        for (int i = 1; i < array.length; i++) {
            int tmp = array[i];
            int j = i-1;
            for (; j >= 0 ; j--) {
                if(array[j] > tmp) {
                    array[j+1] = array[j];
                }else {
                    //array[j+1] = tmp;  只要j回退的时候,遇到了 比tmp小的元素就结束这次的比较
                    break;
                }
            }
            //j回退到了 小于0 的地方
            array[j+1] = tmp;
        }
    }

【希尔排序】

(以了解为主 面试很少考的)

在这里插入图片描述

【分析步骤 】

【选择排序】

  分析步骤;

第一步;将第一个元素下标设置为 i ,设 index  与 i 指向同一个元素

第二部 设置循环 利用 j  循环找出除 第一个元素以为最小的元素 将其交到index下

第三步 将index 与 第一个元素交换

【堆排序】 

注释 !其基本原理还是排序.只其用堆来进行无序间排序,不用遍历进行排序

 public static void createHeap(int[] array) {
     for (int parent = (array.length - 1 - 1) / 2; parent > 0; parent--) {//设置出父亲节点
            shiftDown(array, parent, array.length);//
        }
    }
    public static void shiftDown(int[] array, int parent, int len) {
        int child = 2 * parent + 1;//设置出子节点
        while (child < len) {
            if (child + 1 < len && array[child] < array[child + 1]) {
                child++;//以防有两个子节点 找出两个子节点最大一位
            }
            if (array[child] > array[parent]) {
            swap(array, parent, child);//交换父亲节点和子节点
            parent = child;//从新设置父亲节点
            child = 2*parent+1;
        }else{
            break;
        }
    }
    }
    public static void heapSort(int[] array) {//
        createHeap(  array);
        int end  = array.length-1;//每次交换完最后一位元素减一位
        while(end > 0){
            swap(array,0,end);
            shiftDown(array,0, array.length-1);//这个循环里 向下转型
            end--;
        }
    }

【冒泡排序】

注释;可能是几种排序比较简单的一种

在这里插入图片描述

介绍一个冒泡排序的优化方法; 

【快速排序】

原理简介-总览

    1   从待排序区间选择一个数,作为基准值(pivot)

    2   partition:遍历整个待排序区间, 将比基准小的(可以与基准相同)放在基左侧,将比基准大                   的(可以与基准相同)放在基准右侧。

    3   采用分治思想,对左右两个小区间按照同样的方法进行处理  直到小区间的长度 == 1; 则其                 代表有序,如果长度 ==0, 则代表没有元素。        

 public static void quick(int[] array,int left,int right) {
      if( left >= right) {//判断递归条件 不满足退出
          return;
      }
        int pivot =  partition( array,left,right);//找出基准值
        quick( array, left, pivot-1);//左侧进行递归
        quick( array, pivot+1 ,right);//右侧进行递归
    }
    private static int partition(int[] array,int start,int end) {
            int tmp = array[start];
            while(start< end){// 
                while(start< end &&array[end] >  tmp){//末尾值比tmp大时 将末尾下标减减
                    end--;
                }
               array[start] = array[end];//在右侧遇到比tmp小的元素 进行交换
              while(start< end && array[start] < tmp ){//先从头部进行比较 比tmp小时交换
                  start++;
              }
              array[end] = array[start];
            }
            array[end] = tmp;
            return end;
    }
    public static void quickSort(int[] array) {
       quick(array,0, array.length-1);
        }
}
}

【归并排序】

原理-总览

      归并排序(MERGE-SORT)是建立在归并操作上的一种有效的排序算法,该算法采用分治法(Divide and Conquer)的一个非常典型的应用。将以有序的子序列合并,得到完全有序的序列;即先使每个子序列有序,再使子序列段间有序。若将两个有序表合并成一个有序表,称为二路归并。

在此之前先复习一下(链表题)【合并两个有序链表】(归并排序的基础)

public static int[] mergeArray(int[] array1,int[] array2) {
        //注意判断参数
        int [] tmp = new int[array1.length + array2.length];
        int i = 0;
        int s1 = 0;
        int e1 = array1.length-1;
        int s2 = 0;
        int e2 = array2.length-1;
        while( s1<e1 && s2<e2){
            if(array1[s1] < array2[s2]){
                tmp[i++] = array1[s1++];
 
            }
            if(array1[s1] > array2[s2]){
                tmp[i++] = array2[s2++];
            }
        }
       while( s1<= e1){
           tmp[i++] = array1[s1++];
       }
       while( s2<= e2){
           tmp[i++] = array2[s2++];
       }
        return tmp;

【正文】

【代码简介;】 

 public static void mergeSort1(int[] array) {
 
 mergeSortInternal(array,0,array.length-1) ;
 
 
}
private static void mergeSortInternal(int[] array,int low,int high) {
           if(low > high){
           return ;
           }
   int mid  = (low +(high-low))/2;//找到数组的中间位置 分为左右两部分
    mergeSortInternal( array, low,mid-1 );// 将左边部分进行递归排序
   mergeSortInternal( array, mid+1,high );// 将右边部分进行递归排序  
    merge(array,low,mid,high);// 将两部分进行合并
 
}
private static void merge(int[] array,int low,int mid,int high) {
         int [] tmp = new int[array.length];//创建一个新的数组
             int s1 = low;
             int e1 = mid;
             int s2 = mid+1;
             int e2 = high;
             int i = 0;
     while(s1<e1 && s2<e2){//循环的的条件
       if(array[s1] < array[s2]){
          tmp[i++] =  array[s1++];
         }else{
           tmp[i++] = array[s2++];
          }
      
      }
       while(s1 < s2){//当到这一步 说明左侧比右侧长   将左侧剩余部分衔接到数组中
         tmp[i++] = array[s1++];
     }
      while(s2 < e2){
         tmp[i++] =  array[s2++];//当到这一步 说明左侧比右侧长   将左侧剩余部分衔接到数组中
 
}
for(int j = 0; j < i; j++){//将tmp数组中元素放置array数组中 
     array[i+low] = tmp[j];
 
}
 
 

【排序总结】

到此这篇关于java中几种常见的排序算法总结的文章就介绍到这了,更多相关java排序算法内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: java中几种常见的排序算法总结

本文链接: https://www.lsjlt.com/news/163990.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • java中几种常见的排序算法总结
    目录本节目标;【插入排序】【优化版】【希尔排序】【选择排序】【堆排序】 【冒泡排序】介绍一个冒泡排序的优化方法; 【快速排序】【归并排序】【正文】【代码简介;】&...
    99+
    2022-11-13
  • 盘点几种常见的java排序算法
    目录1.插入排序2.分治排序法,快速排序法3.冒泡排序 low版4.冒泡排序 bigger版5.选择排序6. 归并排序8. 堆排序9. 其他排序10. 比较总结1.插入排序 这个打...
    99+
    2022-11-12
  • java中几种常见的排序算法是什么
    java中几种常见的排序算法是什么,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。1 排序       排序,就是使一串记录,按照其中某个...
    99+
    2023-06-29
  • Java中常见的查找算法与排序算法总结
    目录1. 基本查找2. 二分查找3. 插值查找4. 斐波那契查找5. 分块查找6. 哈希查找7. 树表查找十大排序算法1. 冒泡排序2. 选择排序3. 插入排序4. 快速排序数据结构...
    99+
    2023-03-11
    Java查找算法 Java排序算法 Java查找 排序
  • Java实现几种常见排序算法代码
    稳定度(稳定性)一个排序算法是稳定的,就是当有两个相等记录的关键字R和S,且在原本的列表中R出现在S之前,在排序过的列表中R也将会是在S之前。 排序算法分类 常见的有插入(插入排序/...
    99+
    2022-11-15
    Java 排序算法
  • 总结几种MySQL中常见的排名问题
    前言: 在某些应用场景中,我们经常会遇到一些排名的问题,比如按成绩或年龄排名。排名也有多种排名方式,如直接排名、分组排名,排名有间隔或排名无间隔等等,这篇文章将总结几种MySQL中常见的排名问题。 创建测试表 ...
    99+
    2022-05-16
    MySQL 统计排名 MySQL 排名
  • PHP常见的几种排序算法介绍
    这篇文章主要介绍“PHP常见的几种排序算法介绍”,在日常操作中,相信很多人在PHP常见的几种排序算法介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”PHP常见的几种排序算法...
    99+
    2022-10-19
  • Java中七种排序算法总结分析
    目录前言:对文章出现的一些名词进行解释一、插入排序1.基本思想2.直接插入排序3.希尔排序(缩小增量排序)二、选择排序1.基本思想2.直接选择排序3.堆排序三、交换排序1.基本思想2...
    99+
    2022-11-12
  • 常见的几种排序
    快速排序      从数列中挑出一个元素,称为 “基准”(pivot),重新排序数列,所有元素比基准值小的摆放在基准前面,所有元素比基准值大的摆在基准的后面...
    99+
    2022-10-18
  • python中几种常用的排序算法
    这篇文章主要介绍“python中几种常用的排序算法”,在日常操作中,相信很多人在python中几种常用的排序算法问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”python中几...
    99+
    2022-10-19
  • 详细总结各种排序算法(Java实现)
    一、插入类排序1.直接插入排序思想:将第i个插入到前i-1个中的适当位置时间复杂度:T(n) = O(n²)。空间复杂度:S(n) = O(1)。稳定性:稳定排序。如果碰见一个和插入元素相等的,那么插入元素把想插入的元素放在相等元...
    99+
    2023-05-31
    java 排序算法 ava
  • Android中ListView的几种常见的优化方法总结
    Android中的ListView应该算是布局中几种最常用的组件之一了,使用也十分方便,下面将介绍ListView几种比较常见的优化方法: 首先我们给出一个没有任何优化的Li...
    99+
    2022-06-06
    方法 listview 优化 Android
  • java 算法 6种排序小结
    目录冒泡排序选择排序插入排序希尔排序归并排序快速排序冒泡排序 package 冒泡排序; import java.util.Arrays; public class Bub...
    99+
    2022-11-12
  • 介绍java中的常见排序算法
    Java中的排序算法主要包括以下几种: 冒泡排序(Bubble Sort)选择排序(Selection Sort)插入排序(Insertion Sort)快速排序(Quick Sort)归并排序(Merge Sort)堆排序(Heap So...
    99+
    2023-10-26
    算法 排序算法 数据结构 java 笔记 学习
  • 浅谈Java常见的排序算法
    目录一、直接插入排序二、希尔排序三、冒泡排序四、快速排序五、选择排序(Selection Sort)六、堆排序七、归并排序一、直接插入排序 基本思想: 将一个记录插入到已排序的有序表...
    99+
    2022-11-12
  • 优化常见的java排序算法
    目录冒泡排序原始的写法优化一优化二选择排序方法一方法二堆排序建大堆来实现堆排建小堆来实现堆排插入排序实现优化一优化二归并排序递归实现归并排序优化来看O(n)的排序当然除了基于比较的排...
    99+
    2022-11-12
  • Java数据结构常见几大排序梳理
    目录一、排序的概念和分类1.排序的基本概念2.排序的稳定性二、常见排序1.直接插入排序2.希尔排序3.简单选择排序4.堆排序5.冒泡排序6.快速排序6.1.递归快速排序6.2.非递归...
    99+
    2022-11-13
  • 总结三种常见php算法的实现方法
    PHP是一种强大的脚本语言,它在Web开发领域中广泛应用。除了在网站开发中使用,PHP还可以用于实现各种算法和数据结构。在本文中,我们将介绍三个常见的算法,包括冒泡排序、快速排序和二分查找,以及在PHP中如何实现它们。一、冒泡排序冒泡排序是...
    99+
    2023-05-14
  • Java数据结构常见排序算法有哪些
    今天小编给大家分享一下Java数据结构常见排序算法有哪些的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。1、 认识排序在学校中...
    99+
    2023-07-05
  • Java深入了解数据结构中常见的排序算法
    目录一,概念1,排序2,稳定性二,排序详解1,插入排序①直接插入排序2,选择排序①直接选择排序②堆排序3,交换排序①冒泡排序②快速排序4,归并排序一,概念 1,排序 排序,就是使一串...
    99+
    2022-11-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作