java中sort排序_数据结构算法总结

java中sort排序_数据结构算法总结数组Sort排序正序排序:Arrays.sort(array),会检查数组个数大于286且连续性好就使用归并排序,若小于32使用插入排序,其余情况使用快速排序int[]array={10,3,6,1,4,5,9};Arrays.sort(array);降序排序:先将数组Arrays.asList()转为集合,然后使用Collections.reverse()反转集合,注意如果是基础数据类型(不是数据包装类),不能使用Arrays.asList()方法可以使用Guava的Int..

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

  1. 数组Sort排序

    正序排序:Arrays.sort(array),会检查数组个数大于286且连续性好就使用归并排序,若小于32使用插入排序,其余情况使用快速排序

    int[] array = { 
         10, 3, 6, 1, 4, 5, 9};
    Arrays.sort(array);
    

    降序排序:先将数组Arrays.asList()转为集合,然后使用Collections.reverse()反转集合,注意如果是基础数据类型(不是数据包装类),不能使用Arrays.asList()方法可以使用Guava的Ints.asList()方法代替

    Integer[] array = { 
         10, 3, 6, 1, 4, 5, 9};
    Arrays.sort(array);
    List<Integer> list = Arrays.asList(array);
    Collections.reverse(list);//冒泡 交换
    
  2. 简单集合Sort排序

    说明:主要是对jdk类库中的包装类排序,例如:Integer、String等,这些类都已经重写了Compare方法,都有默认排序规则

    常规方式

    List<Integer> list = new ArrayList<Integer>(Arrays.asList(10, 3, 6, 1, 4, 5, 9));
    // 升序
    Collections.sort(list);
    // 降序
    Collections.sort(list, Collections.reverseOrder());
    

    lambda方式

    // 升序
    List<Integer> collect = list.stream().sorted().collect(Collectors.toList());
    // 降序
    List<Integer> collect = list.stream().sorted(Comparator.reverseOrder()).collect(Collectors.toList());
    
    lists.sort((o1,o2)->o1.getAge()-o2.getAge());
    lists.sort(Comparator.comparing(Person::getAge).reversed().thenComparing(Person::getName));
    
    
  3. 对象集合Sort排序

    lambda方式:排序值不能为null

    //方法二:使用stream sorted方法 
     list=list.stream().sorted((s2,s1 )->s1.getShowOrder().compareTo(s2.getShowOrder())).collect(Collectors.toList());
    //方法三:使用jdk8的sort方法
     list.sort((s2,s1)->s1.getShowOrder().compareTo(s2.getShowOrder()));
    //方法四:总结
        Arrays.sort(array, (v1, v2) -> v1[0] - v2[0]);
        Collections.sort(list, (o1,o2)->o1[0]-o2[0]);
        list.sort((o1, o2) -> o1[0] - o2[0]);
    

    Comparable方式:在实体中实现Comparable<实体>接口,重写compareTo方法,缺点不灵活

    public class Student implements Comparable<Student> { 
         
    	private String name;
    	private Integer age;
    
    	public int compareTo(StudentAsc o) { 
         
      		if(null == this.age) { 
         
          		return -1;
      		}
      		if(null == o.getAge()) { 
         
          		return 1;
      		}
      		return this.age.compareTo(o.getAge());
    	}
    }
    

    Comparator方式:使用Collections.sort(List list, Comparator<? super T> c)方法来实现相对上面来说灵活很多

    Collections.sort(students, new Comparator<Student>() { 
         
     	public int compare(Student o1, Student o2) { 
         
        	if(null == o1.getAge()) { 
         
            	return -1;
        	}
       	 	if(null == o2.getAge()) { 
         
            	return 1;
       	 	}
       	 	return o1.getAge().compareTo(o2.getAge());
     	}
    });
    
  4. Sort方法详解(待补充)

    说明:Collections.sort方法底层就是调用的array.sort方法,根据数据大小的不同会使用插入排序、归并排序、快速排序(后两种排序算法都是分治思想)

参考:
https://blog.csdn.net/whp1473/article/details/79678974
https://blog.csdn.net/MrLiar17/article/details/89188038

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/169884.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • zuul 网关卡死_zuul网关配置

    zuul 网关卡死_zuul网关配置zuul是SpringCloud全家桶中的微服务API网关。

    2022年8月15日
    6
  • dsp调试技巧_keil仿真调试

    dsp调试技巧_keil仿真调试DSP仿真调试步骤1.仿真调试步骤通过USB电缆连接仿真器至主机,操作方法如下:确保设备全部处于断电状态。安装仿真器JTAG电缆,并将JTAG接头连接至目标板。用USB电缆连接仿真器至主机。仿真器上电。目标板上电。2.注意事项目标板或者仿真器带电的情况下,不可插拔仿真器JTAG接口。USB电缆尽量不要使用台式机计算机的前置USB接口连接。正确的上电顺序为:a)设备全部断电b)仿真器JTAG街头连接目标板c)连接USB电缆或者网线d)仿真器上

    2025年9月25日
    5
  • NetScaler实现域名http到https的自动跳转

    NetScaler实现域名http到https的自动跳转很多场景下,有对外提供加密web站点(HTTPS)的需求,比如大部分在线交易/支付网站,SSL×××等都需要终端输入完整的URL如https://www.test.com才能打开页面。但大部分用户的使用习惯是只在浏览器地址栏输入域名,默认以http协议方式打开,但由于服务器端并不存在http://www.test.com,从而无法打开页面,影响用户体验。…

    2022年10月3日
    2
  • PKI 体系

    PKI 体系PKI简介公开密钥基础建设(英语:PublicKeyInfrastructure,缩写:PKI),又称公开密钥基础架构、公钥基础建设、公钥基础设施、公开密码匙基础建设或公钥基础架构,是一组由硬件、软件、参与者、管理政策与流程组成的基础架构,其目的在于创造、管理、分配、使用、存储以及撤销数字证书。(PKI体系(一)-PKI介绍-简书)概念对称加密特点:加解密使用相同密钥,加解密过程速度快 算法:DES、3DES、AES非对称加密特点:加解密各用密钥对其中之一,密钥对公开的部

    2022年8月22日
    6
  • 批处理 %~0_批处理输入

    批处理 %~0_批处理输入%~dp0“d”为Drive的缩写,即为驱动器,磁盘、“p”为Path缩写,即为路径,目录cd是转到这个目录,不过我觉得cd/d%~dp0还好些%~dp0“d”为Drive的缩写,即为驱动器,磁盘、“p”为Path缩写,即为路径,目录cd是转到这个目录,不过我觉得cd/d%~dp0还好些选项语法:~0-删除任何引号(“),扩充%

    2022年9月20日
    8
  • Log4j简单配置

    Log4j简单配置Log4j是一组强大的日志组件,在项目中时常需要用它提供一些信息,这两天学习了一下它的简单配置。第一步,我们需要导入log4j-1.2.14.jar到lib目录下第二步,在src下建立log4j.pr

    2022年7月4日
    26

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号