package com.heima.hashset;
import java.util.ArrayList;
import java.util.Comparator;
import java.util.TreeSet;
public class Demo5_TreeSet {
/*
* 在一个集合中存储了无序并且重复的字符串,定义一个方法,让其有序(字典顺序),而且还不能去除重复
* 分析
* 1,定义一个list集合,存储无序并且重复的字符串
* 2,定义方法对其排序保留重复
* 3,打印list集合
*/
public static void main(String[] args) {
//1,定义一个list集合,存储无序并且重复的字符串
ArrayList<String> list = new ArrayList<>();
list.add("学习");
list.add("学习");
list.add("bbbb");
list.add("cccc");
list.add("cccc");
list.add("你好你好");
list.add("你好你好");
//2,定义方法对其排序保留重复
sort(list);
//3,打印list集合
System.out.println(list);
}
/*定义方法对其排序保留重复
* 分析
* 1,创建TreeSet集合对象,因为String本身就具备比较的功能,但是重复不会保留,所以用比较器
* 2,将list集合中所有的元素添加到treeset集合中,对其排序,保留重复
* 3,清空list集合
* 4,将TreeSet集合中排好序的元素添加到list集合中
*/
private static void sort(ArrayList<String> list) {
//1,创建TreeSet集合对象,因为String本身就具备比较的功能,但是重复不会保留,所以用比较器
TreeSet<String> ts = new TreeSet<>(new Comparator<String>() {
@Override
public int compare(String s1, String s2) {
int num = s1.compareTo(s2);
return num == 0 ? 1: num;
}
});
//2,将list集合中所有的元素添加到treeset集合中,对其排序,保留重复
ts.addAll(list);
//3,清空list集合
list.clear();
// 4,将TreeSet集合中排好序的元素添加到list集合中
list.addAll(ts);
}
}
|
|