一篇文章搞定Java中常用集合的排序方法

这篇具有很好参考价值的文章主要介绍了一篇文章搞定Java中常用集合的排序方法。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

Array · 数组

List · 列表

Collections.sort()

简单类型

复杂对象

使用Lambda表达式

Stream API

Map · 键值对

对 Map 的 Key 进行排序

对 Map 的 Value 进行排序


最近在做算法题的时候,发现排序在大部分题中都不可或缺,今天心血来潮,总结下Java中集合排序常用的方法,基本覆盖了大部分的排序场景(特别是自定义比较器,太好用叻( ̄▽ ̄)/)

文中提到的自然顺序排序,对于可比较大小的数据类型,一般按照从小到大的顺序,无法比较大小的,一般指按字典序升序排列

Array · 数组

使用Arrays.sort()方法对数组进行排序

java 集合排序,Java,java,算法,数据结构,集合,排序

int[] arr = {1, 5, 2, 1, 4};
System.out.println("排序前:"+Arrays.toString(arr));
Arrays.sort(arr);
System.out.println("排序后:"+Arrays.toString(arr));

List · 列表

Collections.sort()

简单类型

使用Collections.sort()方法对List进行排序,可以对List进行原地排序(也就是不创建新的List对象),如下所示

java 集合排序,Java,java,算法,数据结构,集合,排序

List<String> list = new ArrayList<>();
list.add("b");
list.add("d");
list.add("ca");
list.add("da");
System.out.println("排序前:"+list);
Collections.sort(list);
System.out.println("排序后:"+list);

复杂对象

当List中的对象比较复杂,当默认的排序无法满足需求的时候,可以使用Comparator接口,Comparator可以进行自定义的比较逻辑来控制排序方式

java 集合排序,Java,java,算法,数据结构,集合,排序

List<Person> list = new ArrayList<>();
list.add(new Person("李四1", 19));
list.add(new Person("李四2", 29));
list.add(new Person("李四3", 39));
list.add(new Person("李四4", 49));
list.add(new Person("张三1", 59));
list.add(new Person("张三2", 69));
list.add(new Person("张三3", 79));
list.add(new Person("张三4", 89));
System.out.println("按名字排序前:" + list);
Collections.sort(list, new Comparator<Person>() {
    @Override
    public int compare(Person o1, Person o2) {
        //按名字排序
        return o1.getName().compareTo(o2.getName());
    }
});
System.out.println("按名字排序后:" + list);

System.out.println("按年龄排序前:" + list);
Collections.sort(list, new Comparator<Person>() {
    @Override
    public int compare(Person p1, Person p2) {
        return p1.getAge() - p2.getAge();
    }
});
System.out.println("按年龄排序后:" + list);

可以使用Comparable接口进行自然排序 如果有一个类需要排序,可以让改类实现Comparable接口,并实现其compareTo()方法,这样,当要对这个类的对象进行排序时,就可以直接使用Collections.sort()方法

java 集合排序,Java,java,算法,数据结构,集合,排序

List<Person> list = new ArrayList<>();
list.add(new Person("李四1", 19));
list.add(new Person("李四2", 29));
list.add(new Person("李四3", 39));
list.add(new Person("李四4", 49));
list.add(new Person("张三1", 59));
list.add(new Person("张三2", 69));
list.add(new Person("张三3", 79));
list.add(new Person("张三4", 89));
System.out.println("按年龄排序前:" + list);
Collections.sort(list);
System.out.println("按年龄排序后:" + list);

java 集合排序,Java,java,算法,数据结构,集合,排序

static class Person implements Comparable<Person> {
    private String name;
    private int age;

    public Person(String name, int age) {
        this.name = name;
        this.age = age;
    }

    public String getName() {
        return name;
    }

    public int getAge() {
        return age;
    }

    @Override
    public String toString() {
        return "[" + name + "," + age + "]";
    }

    @Override
    public int compareTo(Person o) {
        return Integer.compare(this.getAge(), o.getAge());
    }
}

使用Lambda表达式

java 集合排序,Java,java,算法,数据结构,集合,排序

list.sort((o1, o2) -> o1.compareTo(o2));

Stream API

使用Stream API排序,Java 8还引入了Stream API,它提供了一种流式操作的方式来处理集合数据,Stream API也可以用于对List进行排序

java 集合排序,Java,java,算法,数据结构,集合,排序

List<Integer> sortedList = list.stream().sorted().collect(Collectors.toList());

Map · 键值对

对 Map 的 Key 进行排序

可以使用 TreeMap 来对 Map 的 Key 排序,TreeMap 是有序的保证,底层采用红黑树实现 可以通过比较器 Comparator 对键进行排序,如果没有指定比较器,则按照键自然顺序排序

java 集合排序,Java,java,算法,数据结构,集合,排序

Map<String, Integer> map = new HashMap<>();
map.put("c", 3);
map.put("a", 1);
map.put("b", 2);

Map<String, Integer> treeMap = new TreeMap<>(map);
System.out.println(treeMap);

对 Map 的 Value 进行排序

可以先将 Map 转换成 List,再对 List 进行排序即可 在转换过程中,我们可以使用 Map.Entry 类型的元素来表示键值对,然后将该元素添加到 List 中

java 集合排序,Java,java,算法,数据结构,集合,排序

Map<String, Integer> map = new HashMap<>();
map.put("c", 3);
map.put("a", 1);
map.put("b", 2);


List<Map.Entry<String, Integer>> entryList = new ArrayList<>(map.entrySet());
Collections.sort(entryList, new Comparator<Map.Entry<String, Integer>>() {

    @Override
    public int compare(Map.Entry<String, Integer> o1, Map.Entry<String, Integer> o2) {
        return Integer.compare(o1.getValue(), o2.getValue());
    }
});

// 输出排序后的结果
for (Map.Entry<String, Integer> entry : entryList) {
    System.out.println(entry.getKey() + ":" + entry.getValue());
}

java 集合排序,Java,java,算法,数据结构,集合,排序

Map<String, Person> map2 = new HashMap<>();
map2.put("c", new Person("Tom", 18));
map2.put("a", new Person("Jerry", 20));
map2.put("b", new Person("Alice", 16));

// 将 Map 的 Entry 转换为 List,并按年龄升序排列
List<Map.Entry<String, Person>> list2 = new ArrayList<>(map2.entrySet());
list2.sort((o1, o2) ->
    Integer.compare(o1.getValue().getAge(), o2.getValue().getAge()));

// 输出排序后的结果
for (Map.Entry<String, Person> entry : list2) {
    System.out.println(entry.getKey() + ":" + entry.getValue());
}

搞定、撒个花( ̄∇ ̄)/🎉~~~~~~~~~~文章来源地址https://www.toymoban.com/news/detail-707549.html

到了这里,关于一篇文章搞定Java中常用集合的排序方法的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 一篇文章搞定《Android权限问题(全版本)》

    文章内容如下: 如果你只是想快速的完成你Android权限申请的工作,那么直接上工具PermissionX 如果是想真正的了解Android的权限问题,那么建议你用15分钟通读一下本文。(可以不去实验,收藏以备后用) 首先了解Android版本和SDK的关系,帮助我们分辨后面的权限版本。 其次把最常

    2024年02月03日
    浏览(37)
  • 一篇文章搞定Android权限问题(全版本)

    文章内容如下: 如果你只是想快速的完成你Android权限申请的工作,那么直接上工具PermissionX 如果是想真正的了解Android的权限问题,那么建议你用15分钟通读一下本文。(可以不去实验,收藏以备后用) 首先了解Android版本和SDK的关系,帮助我们分辨后面的权限版本。 其次把最常

    2023年04月20日
    浏览(38)
  • 【Unity】一篇文章搞定AStar(A*)算法

    AStar(A*)算法,是一种在静态网格中求解最短路径直接有效的搜索方法。在游戏开发中,A*算法常应用于部分RPG游戏和策略战棋类游戏。对于Unity开发者来说,掌握A*算法也是十分有必要的。不过在了解A*算法之前,有必要先回顾一下深度优先算法(DFS)、广度优先算法(BFS)

    2024年02月02日
    浏览(39)
  • Spring之AOP(带你一篇文章搞定AOP)

    Spring的核心之一:AOP 用的依赖(包括上篇文章讲诉的IOC依赖): AOP:面向切面编程。利用 AOP 可以对业务逻辑的各个部分进行隔离,从而使得业务逻辑各部分之间的耦合度降低,提高程序的可重用性,同时提高了开发的效率。通俗来说就是在不修改代码的情况下添加新的功能

    2024年02月16日
    浏览(36)
  • 一篇文章搞定什么是nodeJs它和NPM关系与应用

    现在前端的入门门槛越来越高了,不再是单纯 html+css+js ,各种前端框架 层出不穷,各种ui组件库层出不穷。 模块化,打包化,各种工具库层出不穷,前端变成 大前端 ,甚至前端可以搞定整个项目,通过 node 作为服务端api, 这里我们主角就是 nodeJs javaScript是一门脚本语言,

    2024年02月03日
    浏览(33)
  • 一篇文章搞定《实战中的设计模式之Android版》

    其实大多数可能和我一样,在开发项目的累积经验下,和对设计模式隐约的记忆下。 在开发项目的过程中其实已经使用到了设计模式,但是不能自知。 比如:之前开发的基于AI的一个对话IM,里面涉及到了很多的设计模式。但是都是下意识的去使用,甚至连他是那种设计模式

    2024年02月10日
    浏览(31)
  • 一篇文章搞定《动手学深度学习》-(李沐)PyTorch版本的所有内容

    目录 目录 简介 阅读指南 1. 深度学习简介 2. 预备知识 3. 深度学习基础 4. 深度学习计算 5. 卷积神经网络 6. 循环神经网络 7. 优化算法 8. 计算性能 9. 计算机视觉 10. 自然语言处理 环境 参考(大家可以在这里下载代码) 原书地址(大家可以在这里阅读电子版PDF内容) 引用 阅读

    2023年04月24日
    浏览(32)
  • OSPF技术连载16:DR和BDR选举机制,一篇文章搞定!

    你好,这里是网络技术联盟站。 在计算机网络中,开放最短路径优先(Open Shortest Path First,OSPF)是一种广泛使用的内部网关协议(Interior Gateway Protocol,IGP),用于在大型网络中实现路由选择。在OSPF网络中,当一个OSPF区域内有多个路由器时,为了减少链路状态数据库(Link

    2024年02月07日
    浏览(30)
  • 七大 排序算法(一篇文章梳理)

    排序算法是计算机科学中不可或缺的一部分,它们在数据处理、数据库管理、搜索引擎、数据分析等多个领域都有广泛的应用。排序算法的主要任务是将一组数据元素按照某种特定的顺序(如升序或降序)进行排列。本文将对一些常见的排序算法进行详细的介绍和分析,包括

    2024年03月08日
    浏览(41)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包