HashSet唯一特性之案例
1、案例1
需求:编写一个程序,获取10个1至20的随机数,要求随机数不能重复。并把最终的随机数输出到控制台。
分析:
- 有Random类创建随机数对象
- 需要存储10个随机数,而且不能重复,所以我们用HashSet集合
- 如果HashSet的size是小于10就可以不断的存储,如果大于等于10就停止存储
- 通过Random类中的nextInt(n)方法获取1到20之间的随机数,并将这些随机数存储在HashSet集合中
- 遍历HashSet
实现:
public static void main(String[] args) {
//1,有Random类创建随机数对象
Random r = new Random();
//2,需要存储10个随机数,而且不能重复,所以我们用HashSet集合
HashSet<Integer> hs = new HashSet<>();
//3,如果HashSet的size是小于10就可以不断的存储,如果大于等于10就停止存储
while(hs.size() < 10) {
//4,通过Random类中的nextInt(n)方法获取1到20之间的随机数,并将这些随机数存储在HashSet集合中
hs.add(r.nextInt(20) + 1);//nextInt()左闭右开
}
//5,遍历HashSet
for (Integer integer : hs) {
System.out.println(integer);
}
}
2、案例2
需求:使用Scanner从键盘读取一行输入,去掉其中重复字符, 打印出不同的那些字符
分析:
- 创建Scanner对象
- 创建HashSet对象,将字符存储,去掉重复
- 将字符串转换为字符数组,获取每一个字符存储在HashSet集合中,自动去除重复
- 遍历HashSet,打印每一个字符
实现:
public static void main(String[] args) {
//1,创建Scanner对象
Scanner sc = new Scanner(System.in);
System.out.println("请输入一行字符串:");
//2,创建HashSet对象,将字符存储,去掉重复
HashSet<Character> hs = new HashSet<>();
//3,将字符串转换为字符数组,获取每一个字符存储在HashSet集合中,自动去除重复
String line = sc.nextLine();
char[] arr = line.toCharArray();
for (char c : arr) { //遍历字符数组
hs.add(c); //自动装箱
}
//4,遍历HashSet,打印每一个字符
for(Character ch : hs) {
System.out.print(ch);
}
}
3、案例3
需求:将集合中的重复元素去掉
分析:
- 创建List集合存储若干个重复元素
- 单独定义方法去除重复
- 打印一下List集合
实现:
public static void main(String[] args) {
//1,创建List集合存储若干个重复元素
ArrayList<String> list = new ArrayList<>();
list.add("a");
list.add("a");
list.add("a");
list.add("b");
list.add("b");
list.add("b");
list.add("c");
list.add("c");
list.add("c");
list.add("c");
//2,单独定义方法去除重复
getSingle(list);
//3,打印一下List集合
System.out.println(list);
}
/*
* 分析
* 去除List集合中的重复元素
* 1,创建一个LinkedHashSet集合
* 2,将List集合中所有的元素添加到LinkedHashSet集合
* 3,将list集合中的元素清除
* 4,将LinkedHashSet集合中的元素添加回List集合中
*/
public static void getSingle(List<String> list) {
//1,创建一个LinkedHashSet集合
LinkedHashSet<String> lhs = new LinkedHashSet<>();
//2,将List集合中所有的元素添加到LinkedHashSet集合
lhs.addAll(list);
//3,将list集合中的元素清除
list.clear();
//4,将LinkedHashSet集合中的元素添加回List集合中
list.addAll(lhs);
}