hashMap 中key和value互換

一隻叫王木木的程式猿發表於2020-11-03

編寫程式將HashMap(變數a)中key和value互換•放入到新的HashMap (變數b)中.
如果value作為key值出現復情況,留在原HashMap (變最a)中,最後列印出變數a和b集合的數量,
存放有資料的原HashMap
HashMap<String,String> a = new HashMap<String,String>;
互換後的HashMap
HashMap<String,String> b = new HashMap<String,Slring>;
編寫互換邏輯:

		HashMap<String, String> a = new HashMap<String, String>();
        HashMap<String, String> b = new HashMap<String, String>();
        a.put("aaa", "111");
        a.put("bbb", "222");
        a.put("ccc", "333");
        a.put("ddd", "333");

        int index = 0;
        int size = a.size();
        String[] key = new String[size];
        String[] val = new String[size];

        for (String str : a.keySet()) {//keySet 取出hashMap中的所有key
            val[index] = str;
            key[index] = a.get(str);
            index++;
        }

        for (int i = 0; i < size; i++) {
            String s = b.get(key[i]);
            if (s != null) {
                continue;
            }
            b.put(key[i], val[i]);
            a.remove(val[i]);
        }

		System.out.println("map a:"+a.size());
        System.out.println("map b:"+b.size());

輸出結果:
在這裡插入圖片描述

相關文章