在 Java 中对集合进行排序
在 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
相关文章
如何在 Java 中延迟几秒钟的时间
发布时间:2023/12/17 浏览次数:217 分类:Java
-
本篇文章主要介绍如何在 Java 中制造程序延迟。本教程介绍了如何在 Java 中制造程序延时,并列举了一些示例代码来了解它。
如何在 Java 中把 Hashmap 转换为 JSON 对象
发布时间:2023/12/17 浏览次数:187 分类:Java
-
它描述了允许我们将哈希图转换为简单的 JSON 对象的方法。本文介绍了在 Java 中把 Hashmap 转换为 JSON 对象的方法。我们将看到关于创建一个 hashmap,然后将其转换为 JSON 对象的详细例子。
如何在 Java 中按值排序 Map
发布时间:2023/12/17 浏览次数:171 分类:Java
-
本文介绍了如何在 Java 中按值对 Map 进行排序。本教程介绍了如何在 Java 中按值对 Map
进行排序,并列出了一些示例代码来理解它。
如何在 Java 中打印 HashMap
发布时间:2023/12/17 浏览次数:192 分类:Java
-
本帖介绍了如何在 Java 中打印 HashMap。本教程介绍了如何在 Java 中打印 HashMap 元素,还列举了一些示例代码来理解这个主题。
在 Java 中更新 Hashmap 的值
发布时间:2023/12/17 浏览次数:146 分类:Java
-
本文介绍了如何在 Java 中更新 HashMap 中的一个值。本文介绍了如何在 Java 中使用 HashMap 类中包含的两个方法-put() 和 replace() 更新 HashMap 中的值。
Java 中的 hashmap 和 map 之间的区别
发布时间:2023/12/17 浏览次数:79 分类:Java
-
本文介绍了 Java 中的 hashmap 和 map 接口之间的区别。本教程介绍了 Java 中 Map 和 HashMap 之间的主要区别。在 Java 中,Map 是用于以键值对存储数据的接口,
在 Java 中获取用户主目录
发布时间:2023/12/17 浏览次数:218 分类:Java
-
这篇文章向你展示了如何在 Java 中获取用户主目录。本教程介绍了如何在 Java 中获取用户主目录,并列出了一些示例代码以指导你完成该主题。
Java 中 size 和 length 的区别
发布时间:2023/12/17 浏览次数:179 分类:Java
-
这篇文章教你如何知道 Java 中大小和长度之间的区别。本教程介绍了 Java 中大小和长度之间的区别。我们还列出了一些示例代码以帮助你理解该主题。
Java 中的互斥锁
发布时间:2023/12/17 浏览次数:111 分类:Java
-
了解有关 Java 中互斥锁的一切,在计算机科学领域,互斥或互斥被称为并发控制的属性。每台计算机都使用称为线程的最小程序指令序列。有一次,计算机在一个线程上工作。为了更好地理解,