Java 集合操作:HashSet、LinkedHashSet 和 TreeSet

一、HashSet<Student> 集合操作题

你需要实现基于Student对象的两个班级选课集合管理,包括并集、交集、差集统计和批量删除操作。核心是Student类必须重写equals()hashCode()(基于唯一标识id),否则HashSet无法正确识别重复学生。

完整代码
复制代码
关键解释
  • Student类:重写equals()hashCode()是核心,否则HashSet会把"学号相同但对象不同"的学生判定为不同元素。

  • 并集:通过addAll()实现,利用HashSet自动去重特性。

  • 交集:retainAll()会保留两个集合的共同元素(注意:直接调用会修改原集合,因此先复制)。

  • 差集:removeAll()删除当前集合中包含在另一个集合的元素。

  • 批量删除:使用Iterator遍历删除,避免ConcurrentModificationException(增强for循环删除会报错)。

二、LinkedHashSet 有序去重操作题

你需要验证LinkedHashSet的插入有序自动去重特性,完成添加、删除、清空等操作。

完整代码
复制代码
关键解释
  • LinkedHashSet:继承HashSet,底层是"哈希表+双向链表",既保留HashSet的去重特性,又通过链表维护插入顺序。

  • remove()方法:存在元素返回true,不存在返回false,可直接接收返回值验证结果。

三、TreeSet 排序与去重操作题

你需要验证TreeSet的自动排序 (默认升序)和自定义排序特性,TreeSet基于红黑树实现,无重复元素。

完整代码
复制代码
输出结果
复制代码
关键解释
  • TreeSet<Integer>:默认按Comparable接口的自然顺序(整数升序)排序,重复元素自动过滤。

  • 自定义Comparator:优先按字符串长度降序(s2.length() - s1.length()),长度相同时按compareTo()自然升序(中文按Unicode编码,近似拼音顺序)。

四、去除List内重复数字(极简实现)

你需要利用HashSet的构造方法快速去重,这是最简单的实现方式。

完整代码
复制代码
输出结果

去重前:[1, 2, 2, 3, 1, 4, 3] 去重后:[1, 2, 3, 4]

关键解释
  • new HashSet<>(numList):HashSet的构造方法接收一个Collection(List是其子类),自动过滤重复元素。

  • new ArrayList<>(HashSet):将去重后的HashSet转回List,实现极简去重(缺点:丢失原List顺序,若要保留顺序可改用LinkedHashSet)。

五、生成10个1-20不重复随机数 + CSDN趣味文章

你需要用HashSet保证随机数不重复,生成格式规范、有趣的CSDN文章。

完整代码
复制代码
示例输出
复制代码
关键解释
  • 随机数生成:Random.nextInt(20)生成0-19,+1后范围是1-20;用HashSet循环添加,直到size=10,确保不重复。

总结

  1. HashSet核心 :去重依赖equals()+hashCode(),常用addAll()(并集)、retainAll()(交集)、removeAll()(差集)操作。

  2. 集合特性:LinkedHashSet(有序+去重)、TreeSet(排序+去重,支持自定义Comparator)。

  3. 极简去重:List转HashSet再转回List是最简洁的去重方式(丢失顺序用LinkedHashSet)。

  4. 不重复随机数:用HashSet循环生成,直到凑够指定数量,避免手动判重。

相关推荐
摇滚侠7 小时前
macbook shell 客户端推荐 Electerm macbook 版本下载链接
java·开发语言
程序员布吉岛7 小时前
Java 后端定时任务怎么选:@Scheduled、Quartz 还是 XXL-Job?(对比 + 避坑 + 选型)
java·开发语言
C++ 老炮儿的技术栈7 小时前
Qt Creator中不写代如何设置 QLabel的颜色
c语言·开发语言·c++·qt·算法
知无不研7 小时前
lambda表达式的原理和由来
java·开发语言·c++·lambda表达式
逍遥德7 小时前
Sring事务详解之02.如何使用编程式事务?
java·服务器·数据库·后端·sql·spring
笨蛋不要掉眼泪7 小时前
Redis哨兵机制全解析:原理、配置与实战故障转移演示
java·数据库·redis·缓存·bootstrap
lili-felicity7 小时前
CANN多模型并发部署与资源隔离
开发语言·人工智能
小龙报7 小时前
【51单片机】深度解析 51 串口 UART:原理、配置、收发实现与工程化应用全总结
c语言·开发语言·c++·stm32·单片机·嵌入式硬件·51单片机
qq_532453538 小时前
使用 Three.js 构建沉浸式全景图AR
开发语言·javascript·ar
Coder_Boy_8 小时前
基于SpringAI的在线考试系统-整体架构优化设计方案
java·数据库·人工智能·spring boot·架构·ddd