投票系统核心是用HashMap统计票数、HashSet防重复投票、ArrayList存原始记录、Stream排序结果;HashMap以姓名为key计票,HashSet用add()判重,ArrayList存VoteRecord审计,Stream按value降序排入LinkedHashMap。

用Java做投票系统,核心在于用集合高效统计票数,关键不是写界面或网络通信,而是理清数据结构和统计逻辑。下面从实际开发角度讲清楚怎么用List、Map、Set配合完成计票、去重、排序等常见需求。
用HashMap存候选人和票数
候选人名字作为key,得票数作为value,是最直接的统计方式。每次收到一个投票,就对对应key的value加1。
- 初始化:HashMap
votes = new HashMap(); - 计票:votes.put(name, votes.getOrDefault(name, 0) + 1);
- 注意:getOrDefault避免空指针,比先containsKey再get更简洁安全
用HashSet保证一人一票(防重复投票)
如果要求每个用户只能投一次,需记录已投票的用户标识(如ID或手机号),用HashSet快速判断是否已投。
- HashSet
votedUsers = new HashSet(); - 投票前检查:if (!votedUsers.add(userId)) { return "您已投过票"; }
- add()方法返回true表示新增成功,false表示已存在——刚好用来判断重复
用ArrayList存所有投票记录(可选审计用)
有些场景需要查原始投票流水(比如后期核对、导出Excel),可用ArrayList保存每次投票的完整信息。
立即学习“Java免费学习笔记(深入)”;
- 定义类VoteRecord { String userId; String candidate; LocalDateTime time; }
- List
records = new ArrayList(); - 每次投票时new一个对象add进去,不参与实时统计,但为追溯提供依据
用TreeMap或Stream排序结果
展示排名时通常要按票数降序排列。TreeMap不支持直接按value排序,推荐用Stream API处理。
- Map
sorted = votes.entrySet().stream()
.sorted(Map.Entry.comparingByValue(Comparator.reverseOrder()))
.collect(Collectors.toMap(Map.Entry::getKey, Map.Entry::getValue,
(e1, e2) -> e1, LinkedHashMap::new)); - 这样得到的LinkedHashMap保持插入顺序,就是按票数从高到低排好的结果










