遍歷map幾種方式及應用

Map<String, String> map = new HashMap<String, String>();
  map.put("1", "value1");
  map.put("2", "value2");
  map.put("3", "value3");
 
  //第一種:廣泛使用,二次取值
  System.out.println("經過Map.keySet遍歷key和value:");
  for (String key : map.keySet()) {
   System.out.println("key= "+ key + " and value= " + map.get(key));
  }
 
  //第二種
  System.out.println("經過Map.entrySet使用iterator遍歷key和value:");
  Iterator<Map.Entry<String, String>> it = map.entrySet().iterator();
  while (it.hasNext()) {
   Map.Entry<String, String> entry = it.next();
   System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
  }
 
  //第三種:推薦,尤爲是容量大時
  System.out.println("經過Map.entrySet遍歷key和value");
  for (Map.Entry<String, String> entry : map.entrySet()) {
   System.out.println("key= " + entry.getKey() + " and value= " + entry.getValue());
  } 數組

  //第四種
  System.out.println("經過Map.values()遍歷全部的value,但不能遍歷key");
  for (String v : map.values()) {
   System.out.println("value= " + v);
  } get

public class HashMapTest1 {     /**      * 找出一個數組中一個數字出現次數最多的數字      * 用HashMap的key來存放數組中存在的數字,value存放該數字在數組中出現的次數      * @author guolz      */     public static void main(String[] args)     {         int[] array = {2, 1, 2, 3, 4, 5, 2, 2, 2, 2};                  //map的key存放數組中存在的數字,value存放該數字在數組中出現的次數         HashMap<Integer, Integer> map = new HashMap<Integer, Integer>();                  for(int i = 0; i < array.length; i++)         {             if(map.containsKey(array[i]))             {                 int temp = map.get(array[i]);                                  map.put(array[i], temp + 1);             }             else             {                 map.put(array[i], 1);             }         }                  Collection<Integer> count = map.values();                  //找出map的value中最大的數字,也就是數組中數字出現最多的次數         int maxCount = Collections.max(count);                  int maxNumber = 0;                  for(Map.Entry<Integer, Integer> entry : map.entrySet())         {             //獲得value爲maxCount的key,也就是數組中出現次數最多的數字             if(maxCount == entry.getValue())             {                 maxNumber = entry.getKey();             }         }                  System.out.println("出現次數最多的數字爲:" + maxNumber);         System.out.println("該數字一共出現" + maxCount + "次");     } }
相關文章
相關標籤/搜索