java几种基本排序

/** * 冒泡排序 * 比较相邻的元素。如果第一个比第二个大,就交换他们两个。 * 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。 * 针对所有的元素重复以上的步骤,除了最后一个。 * 持续每次对越来越少的元素重复上面...
java几种基本排序
/** * 冒泡排序 * 比较相邻的元素。如果第一个比第二个大,就交换他们两个。 * 对每一对相邻元素作同样的工作,从开始第一对到结尾的最后一对。在这一点,最后的元素应该会是最大的数。 * 针对所有的元素重复以上的步骤,除了最后一个。 * 持续每次对越来越少的元素重复上面的步骤,直到没有任何一对数字需要比较。 * @param numbers 需要排序的整型数组 */ public static void bubbleSort(int[] numbers) { int temp = 0; int size = numbers.length; for(int i = 0 ; i < size-1; i ++) { for(int j = 0 ;j < size-1-i ; j++) { if(numbers[j] > numbers[j+1]) //交换两数位置 { temp = numbers[j]; numbers[j] = numbers[j+1]; numbers[j+1] = temp; } } } }快速排序的基本思想: 通过一趟排序将待排序记录分割成独立的两部分,其中一部分记录的关键字均比另一部分关键字小,则分别对这两部分继续进行排序,直到整个序列有序。/** * 查找出中轴(默认是最低位low)的在numbers数组排序后所在位置 * * @param numbers 带查找数组 * @param low 开始位置 * @param high 结束位置 * @return 中轴所在位置 */ public static int getMiddle(int[] numbers, int low,int high) { int temp = numbers[low]; //数组的第一个作为中轴 while(low < high) { while(low < high && numbers[high] > temp) { high--; } numbers[low] = numbers[high];//比中轴小的记录移到低端 while(low < high && numbers[low] < temp) { low++; } numbers[high] = numbers[low] ; //比中轴大的记录移到高端 } numbers[low] = temp ; //中轴记录到尾 return low ; // 返回中轴的位置 } 递归形式的分治排序算法: /** * * @param numbers 带排序数组 * @param low 开始位置 * @param high 结束位置 */ public static void quickSort(int[] numbers,int low,int high) { if(low < high) {   int middle = getMiddle(numbers,low,high); //将numbers数组进行一分为二   quickSort(numbers, low, middle-1); //对低字段表进行递归排序   quickSort(numbers, middle+1, high); //对高字段表进行递归排序 } }2018-05-30
mengvlog 阅读 11 次 更新于 2025-06-20 01:19:31 我来答关注问题0
  •  猪八戒网 Java中List排序的3种方法!

    1.使用 Comparable 排序按照本文设计的场景,我们需要创建一个包含了用户列表的 List 集合,并按用户的年龄从大到小进行排序,具体实现代码如下:publicclassListSortExample{publicstaticvoidmain(String[]args){//创建并初始化ListListlist=newArrayList(){{add(newPerson(1,30,"北京"))...

  • 1、冒泡排序 特点:效率低,实现简单 思想(从小到大排):每一趟将待排序序列中最大元素移到最后,剩下的为新的待排序序列,重复上述步骤直到排完所有元素。这只是冒泡排序的一种,当然也可以从后往前排。2、选择排序 特点:效率低,容易实现。思想:每一趟从待排序序列选择一个最小的元素放到已排好...

  •  百度网友01460bb Java数组排序 几种排序方法详细一点

    JAVA中在运用数组进行排序功能时,一般有四种方法:快速排序法、冒泡法、选择排序法、插入排序法。快速排序法主要是运用了Arrays中的一个方法Arrays.sort()实现。冒泡法是运用遍历数组进行比较,通过不断的比较将最小值或者最大值一个一个的遍历出来。选择排序法是将数组的第一个数据作为最大或者最小的...

  •  文暄生活科普 Java 8 排序的 10 个姿势,太秀了吧!同事直呼看不懂。

    Stream 排序:List 转 Stream,使用 sorted 方法,同样接受 Lambda、方法引用或 Comparator 工具方法。并行 Stream 排序:使用 parallelStream 方法,实现并行排序。Collections 排序:使用 Lambda、方法引用或 Comparator 工具方法,修改 Collections 工具类。总结:本文列举了 Java 8 的 10 种排序方法,分为三...

  •  翡希信息咨询 java数组排序的方法

    Java数组排序的主要方法有以下几种:一、冒泡排序 冒泡排序是一种简单的排序算法,通过重复遍历待排序数组,比较每对相邻元素并交换它们,直到没有需要交换的元素为止,此时数组已排序完成。二、选择排序 选择排序通过每次从未排序部分选出最小元素,并将其放置到已排序部分的末尾,直到所有元素都排序完成。...

檬味博客在线解答立即免费咨询

Java相关话题

Copyright © 2023 WWW.MENGVLOG.COM - 檬味博客
返回顶部