(14-1)使用Lambda表达式,结合TreeSet集合实现数字倒序排序,即从大到小的排序。java
时间: 2023-12-10 17:37:23 浏览: 202
可以使用以下代码实现:
```java
TreeSet<Integer> set = new TreeSet<>((a, b) -> b - a);
set.add(3);
set.add(1);
set.add(5);
set.add(2);
System.out.println(set); // 输出 [5, 3, 2, 1]
```
在这里,我们创建了一个 TreeSet 对象,并传入了一个 Lambda 表达式作为比较器。这个比较器将会根据传入的两个参数(即集合中的两个元素)进行排序,返回值为正数表示第二个参数大于第一个参数,返回值为负数表示第一个参数大于第二个参数,返回值为 0 表示两个参数相等。这里我们使用 `b - a` 来实现从大到小的排序。
然后我们向集合中添加了一些数字,最后打印出来时可以看到它们已经按照从大到小的顺序排列了。
相关问题
使用Lambda表达式,结合TreeSet集合实现数字倒序排序,即从大到小的排序。
可以使用Lambda表达式来实现TreeSet集合中的自定义比较器,从而实现数字倒序排序。代码如下:
```java
TreeSet<Integer> set = new TreeSet<>((a, b) -> b - a);
```
在这个比较器中,Lambda表达式 `(a, b) -> b - a` 表示如果 `b - a` 的值大于0,则认为b大于a,因此将b排在a的前面,从而实现数字倒序排序。
完整代码如下:
```java
import java.util.TreeSet;
public class Main {
public static void main(String[] args) {
TreeSet<Integer> set = new TreeSet<>((a, b) -> b - a);
set.add(1);
set.add(3);
set.add(2);
set.add(5);
set.add(4);
System.out.println(set); // [5, 4, 3, 2, 1]
}
}
```
阅读全文