Java:如何保存SET 作为HashMap中的值?

问题描述 投票:0回答:7

我希望有以下数据结构来存储具有多个ID(int)的单词,但我不知道如何将键值对放入以下变量“myWord”

Map<String, Set<Integer>> myWord = new HashMap<String, Set<Integer>>();

myWord.put(“word1”,如何将ID添加到此处的Set?)

谢谢

java hashmap set
7个回答
4
投票
Map<String, Set<Integer>> myWord = new HashMap<String, Set<Integer>>();
Set<Integer> mySet = new HashSet<Integer>();
myWord.put("word1", mySet);

3
投票
Set<Integer> mySet = new HashSet<Integer>(); // create a set of IDs
mySet.add(1); // add Id to set
mySet.add(2); // add Id to set
myWord.put("word1", mySet); // finally put set in your map

1
投票
Set<Integer> set=new HashSet<>();
set.add(id);// Similarly all ids here
myWord.put("word1", set)

0
投票
Set mySet = new HashSet<Integer>();
mySet.add(3);
Map<String, Set<Integer>> myWord = new HashMap<String, Set<Integer>>();

myWord.put("word1", mySet);

0
投票

您也可以考虑使用HashMultimap,它更强大地代表您正在尝试构建的数据结构。

Multimap<String, Integer> myWord = HashMultimap.create();
myWord.put("word1", 2);

0
投票
Set<Integer> mySet = new HashSet<Integer>(); // create a set of ids for each word
mySet.add(1); // add Id to the set
mySet.add(2); // add Id to the set
myWord.put("word1", mySet); // for every word put the corresponding set in the map

0
投票
    Map<Integer, Set<Integer>> adjacent = new HashMap<Integer,Set<Integer>>(n);
    for (int i = 0; i < m; i++) {
        int nodeA = s.nextInt();
        int nodeB = s.nextInt();
        if (!adjacent.containsKey(nodeA)) { **checking if the nodes contains A** 
            adjacent.put(nodeA, new HashSet<Integer>()); **If node A is not present it is being added**
        } 
        adjacent.get(nodeA).add(nodeB); **At the end node B is added to node A's list**
    }
© www.soinside.com 2019 - 2024. All rights reserved.