如何检查java散列表是否包含来自另一个散列表的键值对

时间:2016-03-20 22:30:11

标签: java hashtable

是否有内置的java方法来检查一个哈希表是否包含另一个哈希表中存在的所有键值对?

例如:

h1={{0,1},{1,4},{2,5},{3,6}}
h2={{0,1},{2,5}}

在这种情况下,h1包含来自h2的键值对。

2 个答案:

答案 0 :(得分:2)

Hashtable上没有方法可让您直接对此进行检查,但您可以在每个Hashtable上使用entrySet()方法获取Set所有密钥 - 价值对。

然后您可以使用containsAll()来查看其中一个是否是另一个的子集,因为它

  

如果此set包含指定collection的所有元素,则返回true。 如果指定的集合也是一个集合,则此方法如果是此集合的子集则返回true。

e.g。

//  h1={{0,1},{1,4},{2,5},{3,6}}
    Hashtable<Integer, Integer> h1 = new Hashtable<>();
    h1.put(0, 1);
    h1.put(1, 4);
    h1.put(2, 5);
    h1.put(3, 6);

//  h2={{0,1},{2,5}}
    Hashtable<Integer, Integer> h2 = new Hashtable<>();
    h2.put(0, 1);
    h2.put(2, 5);

    Set<Entry<Integer, Integer>> e1 = h1.entrySet();
    Set<Entry<Integer, Integer>> e2 = h2.entrySet();

    System.out.println(e2.containsAll(e1));  // false
    System.out.println(e1.containsAll(e2));  // true

答案 1 :(得分:0)

这是一个小样本程序,用于演示如何匹配2个不同地图的键或键和值:

    public class HashMapMatch {

        public boolean hasMatchingKey(String key, Map m1, Map m2){
            return m1.containsKey(key) && m2.containsKey(key);
        }

        public boolean hasMatchingKeyAndValue(String key, Map m1, Map m2){
            if(hasMatchingKey(key, m1, m2)){
                return m1.get(key).equals(m2.get(key));
            }
            return false;
        }

        public static void main(String[] args) {
            HashMapMatch matcher = new HashMapMatch();
            Map<String, Integer> map1 = new HashMap<>();
            map1.put("One",1);
            map1.put("Two",22);
            map1.put("Three",3);

            Map<String, Integer> map2 = new HashMap<>();
            map2.put("One",1);
            map2.put("Two",2);
            map2.put("Four",4);

            System.out.println("Has matching key? :" + matcher.hasMatchingKey("One", map1, map2));
            System.out.println("Has matching key? :" + matcher.hasMatchingKey("Two", map1, map2));
            System.out.println("Has matching key? :" + matcher.hasMatchingKey("Three", map1, map2));

            System.out.println("Has matching key value: :" + matcher.hasMatchingKeyAndValue("One", map1,map2));
            System.out.println("Has matching key value: :" + matcher.hasMatchingKeyAndValue("Two", map1,map2));

        }
    }

产生输出:

Has matching key? :true
Has matching key? :true
Has matching key? :false
Has matching key value: :true
Has matching key value: :false