Map集合案例-统计投票人数

需求:

某个班级80名学生,现在需要组成秋游活动,班长提供了四个景点依次是(A、B、C、D),每个学生只能选择一个景点,请统计出最终哪个景点想去的人数最多。

 利用Map集合进行统计

//A06_HashMapDemo2.java
package dailyTest;

import javax.persistence.criteria.CriteriaBuilder;
import java.util.*;

/**
 * @author fanfangyu1
 * @createtime 2023/9/12 10:57
 */
public class A06_HashMapDemo2 {
    public static void main(String[] args) {
        /**
         * 某个班级80名学生,现在需要组咸亨秋游活动
         * 班长提供了四个景点依次是(A、B、C、D);
         * 每个学生只能选择一个景点,请统计出最终哪个景点想去的人数最多。
         */
        //1.需要先让同学们投票
        //定义一个数组,存储4个景点
        String[] arr = {"A","B","C","D"};
        //利用随机数模拟80个同学的投票,并把投票的结果存储起来
        ArrayList<String> list = new ArrayList<>();
        Random r = new Random();
        for (int i = 0; i < 80; i++) {
            int index = r.nextInt(arr.length);
//            System.out.println(arr[index]);
            list.add(arr[index]);
        }
        //2.统计
        HashMap<String, Integer> hm = new HashMap<>();
        for (String name:list){
            //判断当前景点在map集合中是否存在
            if(hm.containsKey(name)){
                //存在
                //先获取当前景点已经投票的次数
                Integer count = hm.get(name);
                //表示当前景点又被投了一次
                count++;
                //把新的次数再次添加到集合当中
                hm.put(name,count);
            }else {
                hm.put(name,1);
            }
        }
        System.out.println(hm);
        //3.求最大值
        int max = 0;
        Set<Map.Entry<String, Integer>> entries = hm.entrySet();
        for (Map.Entry<String, Integer> entry : entries) {
            Integer count = entry.getValue();
            if (count>max){
                max = count;
            }
        }
        System.out.println(max);

        //4.判断哪个景点的次数最大值一样,如果一样,打印出来
        for (Map.Entry<String, Integer> entry : entries) {
            Integer count = entry.getValue();
            if (count == max){
                System.out.println(entry.getKey());
            }
        }

    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值