利用Map完成一個(gè)小題目

題目描述:隨機(jī)產(chǎn)生50個(gè)整數(shù),位于[10,50], 統(tǒng)計(jì)每個(gè)數(shù)字出現(xiàn)的次數(shù)以及出現(xiàn)次數(shù)最多的數(shù)字與出現(xiàn)次數(shù)并打印.如果出現(xiàn)次數(shù)為0不打印,打印時(shí)要求升序

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Iterator;
import java.util.Map;
import java.util.Random;
import java.util.Set;
import java.util.TreeMap;

public class MapTest5
{
    public static void main(String[] args)
    {
        //利用TreeMap的有序性,存儲(chǔ)數(shù)字及其出現(xiàn)次數(shù),key為數(shù)字,value為次數(shù)
        TreeMap<Integer, Integer> map = new TreeMap<>();
        //用來存放出現(xiàn)最大次數(shù)的數(shù)字
        ArrayList<Integer> list = new ArrayList<>();
        
        Random random = new Random();
        
        for(int i = 0; i < 40; i++)
        {
            int num =random.nextInt(41) + 10;
            
            if (map.get(num) == null)
            {
                map.put(num, 1);
            }
            else 
            {
                int count = map.get(num);
                map.put(num, count + 1);
            }   
        }
        
        //利用map.value()方法得到值得集合
        Collection<Integer> values = map.values();
        //然后利用Collections.max()得到值中的最大值,即出現(xiàn)的最大次數(shù)
        Integer maxValue =Collections.max(values);
        
        //遍歷map
        Set<Map.Entry<Integer, Integer>> set = map.entrySet();
        for(Iterator<Map.Entry<Integer, Integer>> iterator = set.iterator(); iterator.hasNext();)
        {
            Map.Entry<Integer, Integer> entry = iterator.next();
            Integer key = entry.getKey();
            Integer value = entry.getValue();
            //保存出現(xiàn)最大次數(shù)的數(shù)字
            if(value.equals(maxValue))
                list.add(key);
            System.out.println(key + "的出現(xiàn)次數(shù)為:" + value);
        }
        
        
        System.out.println("出現(xiàn)最多的次數(shù)為:" +  maxValue);
        System.out.print("這些數(shù)字分別是:");
        for(Iterator<Integer> iterator = list.iterator(); iterator.hasNext();)
        {
            System.out.print(iterator.next() + " ");
        }
    }
}

上一篇:Map
下一篇:自定義TreeMap的比較器

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 1. Java基礎(chǔ)部分 基礎(chǔ)部分的順序:基本語法,類相關(guān)的語法,內(nèi)部類的語法,繼承相關(guān)的語法,異常的語法,線程的語...
    子非魚_t_閱讀 34,628評論 18 399
  • Android 自定義View的各種姿勢1 Activity的顯示之ViewRootImpl詳解 Activity...
    passiontim閱讀 178,828評論 25 709
  • 朝花夕拾 今朝早已敵不過舊有 黃昏之后 人去 樓中只留下空洞 浩瀚蒼穹 在滿天星斗下邂逅 茫茫江河 不知 一切是否...
    吃不到草的長頸鹿閱讀 181評論 2 2
  • 凱文·凱利被稱為“互聯(lián)網(wǎng)預(yù)言帝”,2010年的《失控》還沒有拜讀,先從《必然》開始。這是最近讀的書里比較晦澀的一本...
    職場王老師閱讀 693評論 0 0
  • 一周一書《Reality is broken》:我們再也不能抱殘守缺,固執(zhí)地認(rèn)為游戲獨(dú)立于我們的現(xiàn)實(shí)生活和工作。它...
    彭小六閱讀 7,666評論 26 40

友情鏈接更多精彩內(nèi)容