java-容器-collection的sort方法

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Java中如果需要对一个collections排序,需要继承于Comparable或者comparator接口,那么使用的排序算法是什么呢,一般情况下,排序算法包括:插入排序、快速排序、合并排序、冒泡排序等,java的Collections.sort算法调用的是合并排序,它是稳定排序,当数据接近有序的时候,效率更高,collections中的数据在排序前需要输入到array中,接着调用Arrays.sort函数来完成对象排序,最近通过迭代器将数组中排好序的对象些人到collection中,这也要求collection必须为mutable类型的。
Java中如果需要对一个collections排序,需要继承于Comparable或者comparator接口,那么使用的排序算法是什么呢,一般情况下,排序算法包括:插入排序、快速排序、合并排序、冒泡排序等,java的Collections.sort算法调用的是合并排序,它是稳定排序,当数据接近有序的时候,效率更高,collections中的数据在排序前需要输入到array中,接着调用Arrays.sort函数来完成对象排序,最近通过迭代器将数组中排好序的对象些人到collection中,这也要求collection必须为mutable类型的。合并排序的大致过程为:
 
 
void  mergerSort ( int []  a ){
  int  len  =  a . lenght ()
  int  mid  =  len >> 2
  if ( len > 1 ){
    int []  pre = a [ 0 : mid );
    int []  after = a [ mid : len );
   mergerSort ( pre );
   mergerSort ( after );
  merge ( a , pre , after )
}
}
1.collections转化为array,并借助于arrays的sort功能完成排序,并回写到collection
 
 

public static <T> void sort(List<T> list, Comparator<? super T> c) { Object[] a = list.toArray(); Arrays.sort(a, (Comparator)c); ListIterator i = list.listIterator(); for (int j=0; j<a.length; j++) { i.next(); i.set(a[j]); } }

2. Arrays合并排序的实现:
 
 

public static <T> void sort(T[] a, Comparator<? super T> c) { if (LegacyMergeSort.userRequested) legacyMergeSort(a, c); else TimSort.sort(a, c); } /** To be removed in a future release. */ private static <T> void legacyMergeSort(T[] a, Comparator<? super T> c) { T[] aux = a.clone(); if (c==null) mergeSort(aux, a, 0, a.length, 0); else mergeSort(aux, a, 0, a.length, 0, c); }

private static void mergeSort(Object[] src, Object[] dest, int low, int high, int off) { int length = high - low; // Insertion sort on smallest arrays if (length < INSERTIONSORT_THRESHOLD) { for (int i=low; i<high; i++) for (int j=i; j>low && ((Comparable) dest[j-1]).compareTo(dest[j])>0; j--) swap(dest, j, j-1); return; } // Recursively sort halves of dest into src int destLow = low; int destHigh = high; low += off; high += off; int mid = (low + high) >>> 1; mergeSort(dest, src, low, mid, -off); mergeSort(dest, src, mid, high, -off); // If list is already sorted, just copy from src to dest. This is an // optimization that results in faster sorts for nearly ordered lists. if (((Comparable)src[mid-1]).compareTo(src[mid]) <= 0) { System.arraycopy(src, low, dest, destLow, length); return; } // Merge sorted halves (now in src) into dest for(int i = destLow, p = low, q = mid; i < destHigh; i++) { if (q >= high || p < mid && ((Comparable)src[p]).compareTo(src[q])<=0) dest[i] = src[p++]; else dest[i] = src[q++]; } }


注>>:二进制右移,左侧补符号位,>>>:二进制右移,左侧补无符号为,也就是0

3.举例:
 
 
public   class   TestCompare   {
     private   String  com ;
     private   int  id ;
     public   TestCompare ( int  id ,   String  com )   {
         super ();
         this . com  =  com ;
         this . id  =  id ;
     }
     @Override
     public   String  toString ()   {
         return   "TestCompare [com="   +  com  +   ", id="   +  id  +   "]" ;
     }
     /**
     * @param args
     */
     public   static   void  main ( String []  args )   {
         // TODO Auto-generated method stub
         List < TestCompare >  li  =   new   ArrayList < TestCompare >();
        li . add ( new   TestCompare ( 1 ,   null ));
        li . add ( new   TestCompare ( 2 ,   "dfsd" ));
        li . add ( new   TestCompare ( 3 ,   null ));
        li . add ( new   TestCompare ( 4 ,   "ying" ));
         Collections . sort ( li ,   new   Comparator < TestCompare >()   {
             @Override
             public   int  compare ( TestCompare  o1 ,   TestCompare  o2 )   {
                 // TODO Auto-generated method stub
                if (o1.com == o2.com)
                    return 0;
                else if (o1.com == null)
                    return 1;
                else if (o2.com == null)
                    return -1;
                else
                    return o1.com.compareTo(o2.com);
            }
         });
List中含有4个元素,根据合并排序的算法,首先分为[0:2) 和[2:4)
接着[0,2)分为[0:1) 和[1:2)
[0:1):TestCompare [com=null, id=1]
[1:2):TestCompare [com=dfsd, id=2]
合并排序后为
TestCompare [com=dfsd, id=2]
TestCompare [com=null, id=1]
接着执行[2:4),分为[2:3) 和[3:4)
[2:3):TestCompare [com=null, id=3]
[3:4):TestCompare [com=ying, id=4]
合并排序后为:
TestCompare [com=ying, id=4]
TestCompare [com=null, id=3]

将两组合并的数据进行再次合并,及为:
TestCompare [com=dfsd, id=2]
TestCompare [com=ying, id=4]
TestCompare [com=null, id=1]
TestCompare [com=null, id=3]
目录
相关文章
|
1月前
|
算法 Java 开发者
Java 项目实战数字华容道与石头迷阵游戏开发详解及实战方法
本文介绍了使用Java实现数字华容道和石头迷阵游戏的技术方案与应用实例,涵盖GUI界面设计、二维数组操作、游戏逻辑控制及自动解法算法(如A*),适合Java开发者学习游戏开发技巧。
156 47
|
2月前
|
安全 Java API
Java 17 及以上版本核心特性在现代开发实践中的深度应用与高效实践方法 Java 开发实践
本项目以“学生成绩管理系统”为例,深入实践Java 17+核心特性与现代开发技术。采用Spring Boot 3.1、WebFlux、R2DBC等构建响应式应用,结合Record类、模式匹配、Stream优化等新特性提升代码质量。涵盖容器化部署(Docker)、自动化测试、性能优化及安全加固,全面展示Java最新技术在实际项目中的应用,助力开发者掌握现代化Java开发方法。
93 1
|
2月前
|
安全 Java API
Java 集合高级应用与实战技巧之高效运用方法及实战案例解析
本课程深入讲解Java集合的高级应用与实战技巧,涵盖Stream API、并行处理、Optional类、现代化Map操作、不可变集合、异步处理及高级排序等核心内容,结合丰富示例,助你掌握Java集合的高效运用,提升代码质量与开发效率。
175 0
|
2月前
|
算法 搜索推荐 Java
Java中的Collections.shuffle()方法及示例
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,支持原地修改。可选传入自定义 `Random` 对象以实现结果可重复,适用于抽奖、游戏、随机抽样等场景。
73 0
|
2月前
|
安全 Java
JAVA:Collections类的shuffle()方法
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的工具方法,适用于洗牌、抽奖等场景。该方法直接修改原列表,支持自定义随机数生成器以实现可重现的打乱顺序。使用时需注意其原地修改特性及非线程安全性。
72 0
|
2月前
|
算法 安全 Java
java中Collections.shuffle方法的功能说明
`Collections.shuffle()` 是 Java 中用于随机打乱列表顺序的方法,基于 Fisher-Yates 算法实现,常用于洗牌、抽奖等场景。可选 `Random` 参数支持固定种子以实现可重复的随机顺序。方法直接修改原列表,无返回值。
70 0
|
2月前
|
Java 程序员 项目管理
Java 程序员不容错过的 Git Flow 全套学习资料及应用方法详解 Git Flow
本文详细介绍了Git Flow技术方案及其在Java项目中的应用实例,涵盖分支管理、版本发布与紧急修复流程,帮助开发者掌握高效的代码管理方法,提升团队协作效率。附示例操作及代码下载链接。
59 0
|
2月前
|
存储 监控 测试技术
如何将现有的应用程序迁移到Docker容器中?
如何将现有的应用程序迁移到Docker容器中?
189 57
|
2月前
|
存储 监控 Java
如何对迁移到Docker容器中的应用进行性能优化?
如何对迁移到Docker容器中的应用进行性能优化?
198 58
|
2月前
|
NoSQL Redis Docker
使用Docker Compose工具进行容器编排的教程
以上就是使用Docker Compose进行容器编排的基础操作。这能帮你更有效地在本地或者在服务器上部署和管理多容器应用。
257 11