使用Map统计随机数出现的次数

使用Map统计随机数出现的次数

题:统计随机数字出现的次数,以及出现次数最多的数字和次数分别是多少?

解答:
使用Map不可存储相同键的属性来统计,如果在Map中没有出现该数字,那么它出现的次数就为1;如果在Map中已经存在该数字,那么把该值出现的次数+1

import java.util.*;

public class MapCountWords {
    public static void main(String[] args) {
        /**
        * 统计随机数字出现的次数,以及出现次数最多的次数是多少?
        */
        TreeMap<Integer,Integer> map = new TreeMap();
        for (int i = 0; i < 50; i++) {
            int num = (int) (Math.random() * 40 + 10);
            //如果该值在map中没有出现,则出现次数为1
            if (map.get(new Integer(num)) == null) {
                map.put(new Integer(num), 1);
            } else {
                //如果该值在map中存在,则把出现次数+1
                map.put(num, ((Integer)map.get(num)).intValue()+1);
            }
        }
        for (Map.Entry<Integer,Integer> entry : map.entrySet()){
            System.out.println(entry);
        }
        //计算最大的次数
        Collection collect =  map.values();
        Integer max = (Integer) Collections.max(collect);
        System.out.println("出现最多次数为:" + max);
    }
}

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章