迹忆客 专注技术分享

当前位置:主页 > 学无止境 > 编程语言 > Java >

在 Java 中对集合进行排序

作者:迹忆客 最近更新:2023/10/17 浏览次数:

在 Java 中,集合或 HashSet 通常用于随机访问元素,因为使用哈希码访问哈希表元素。哈希码是帮助我们识别哈希表元素的唯一标识。

HashSet 是一个无序集合。Java 中的集合没有随机访问方法(如 get(i),其中 i 是该元素的索引),这是排序算法的基本要求。简而言之,由于 HashSet 的元素是随机放置的,因此由于未定义的顺序,它不提供任何对其元素进行排序的保证。

因此,我们需要开箱即用地思考在 Java 中对集合进行排序。我们将讨论几种将其转换为不同结构并对其进行排序的方法。


在 Java 中使用列表显示排序集

HashSet 进行排序的一种方法是首先将其转换为列表,然后对其进行排序。

我们将集合中的元素添加到列表中,然后使用 sort() 函数对其进行排序。

例如,

import java.util.*;
public class example{

     public static void main(String[] args) {
        HashSet<Integer> number = new HashSet<>();

        // Using add() method
        number.add(3);
        number.add(6);
        number.add(4);
        
        // converting HashSet to arraylist
        ArrayList<Integer> al = new ArrayList<>(number);
        
        // sorting the list and then printing
        Collections.sort(al);
        System.out.println("Sorted list: ");
        for(int x: al) {
            System.out.print(x + " ");
        }
    }
}

输出:

Sorted list: 
3 4 6 

在 Java 中使用 TreeSet 显示排序集

Collections 接口的 TreeSet 类为我们提供了树数据结构的功能。当我们遍历这个集合时,我们可以将 HashSet 转换为 TreeSet。元素以明确定义的顺序提取。
TreeSet 实现了 NavigableSet 接口,它扩展了 SortedSet,进一步扩展了 Set 接口。

请参考以下示例。

import java.util.*;
public class example{
     public static void main(String[] args) {
        HashSet<Integer> number = new HashSet<>();

        // Using add() method
        number.add(3);
        number.add(6);
        number.add(4);

        // TreeSet gets the value of hashSet
        TreeSet myTreeSet = new TreeSet();
        myTreeSet.addAll(number);
        System.out.println(myTreeSet);
    }
}

输出:

[3, 4, 6]

在 Java 中使用 stream() 函数显示排序集

使用 stream() 方法有一个简洁的方法可以解决这个问题。流 API 是在 Java 8 中引入的,它本身并不是一种数据结构。但是,它可以从不同的集合中获取对象,并基于管道方法以所需的方式显示它们。

对于我们的示例,我们将使用 sorted() 方法以排序方式显示最终序列。

请参考下面的代码。

import java.util.*;
public class example {
    public static void main(String []args){
        // creating hashset hs
        HashSet<Integer> hs = new HashSet<>();
        
        // Using add() method to add elements to hs
        hs.add(20);
        hs.add(4);
        hs.add(15);
        
        // before sorting hs
        hs.forEach(System.out::println); 
        System.out.println(); // extra line
        // after sorting hs
        hs.stream().sorted().forEach(System.out::println); // yes
     }
}

输出:

20
4
15

4
15
20

转载请发邮件至 1244347461@qq.com 进行申请,经作者同意之后,转载请以链接形式注明出处

本文地址:

相关文章

Java 中的动态方法调度

发布时间:2023/10/18 浏览次数:199 分类:Java

本教程展示了 Java 中动态方法分派的定义、优势和使用。本教程介绍了 Java 中的动态方法分派。它讲述了它的技术定义和重要性,并用代码示例进行了解释。

Java 中的 abs() 方法

发布时间:2023/10/18 浏览次数:184 分类:Java

本教程通过 Java 中的不同代码示例介绍如何使用 abs() 方法。我们将学习 Java 中的 abs() 方法来查找指定数字的绝对值。我们将通过编写和练习各种代码示例来学习。

在 Java 中使用 System.exit() 方法

发布时间:2023/10/18 浏览次数:157 分类:Java

本文介绍 Java 中 System.exit() 方法的作用。本教程介绍了 Java 中的 System.exit() 方法的作用。System 是 Java 中的一个类,它提供了几种实用方法来处理与系统相关的任务,例如 exit() 方法用于停止当前

在 Java 中编写本机方法

发布时间:2023/10/18 浏览次数:57 分类:Java

本文演示了本机方法是什么以及如何在 Java 程序中编写本机方法。本文将引导你完成学习如何在 Java 程序中编写本机方法所需的各个步骤。

Java 中静态方法和非静态方法的区别

发布时间:2023/10/18 浏览次数:134 分类:Java

本教程对 Java 中的静态和非静态方法进行了分类,同时区分了它们的核心属性和范围。之后,我们将对这两种方法运行三个示例。

Java 中的私有方法

发布时间:2023/10/18 浏览次数:51 分类:Java

本教程演示了 Java 中私有方法的使用。Java 中的私有方法有一个私有访问修饰符,这意味着它们对定义类的访问受到限制,并且在继承的子类中不可访问;这就是为什么他们没有资格覆盖。

Java 中的流过滤器

发布时间:2023/10/18 浏览次数:130 分类:Java

本文介绍 Java 中的流 API 及其过滤方法。本教程介绍 Java 中的流 API 及其 filter() 方法。在 Java 中,流是对象的集合。

Java 中的方法重载

发布时间:2023/10/18 浏览次数:186 分类:Java

本教程简要介绍了 Java 中的方法重载。它还演示了我们如何以及何时可以在 Java 编程中使用方法重载。如果你正在学习 Java 编程,你可能听说过方法重载。我们将在本文中介绍 Java 中的方法重载

Java 中的方法隐藏

发布时间:2023/10/18 浏览次数:137 分类:Java

本文介绍了 Java 中方法隐藏的概念。在本文中,我们将研究 Java 中方法隐藏的概念。方法隐藏类似于重载,但是当对子类和父类中的静态函数使用相同的方法签名时,它就会发挥作用。

扫一扫阅读全部技术教程

社交账号
  • https://www.github.com/onmpw
  • qq:1244347461

最新推荐

教程更新

热门标签

扫码一下
查看教程更方便