Java 如何在HashMap中保留重复项
我不需要删除重复项Java 如何在HashMap中保留重复项,java,hashmap,Java,Hashmap,我不需要删除重复项 HashMap<Integer,String> hm=new HashMap(); hm.put(3,"aba"); hm.put(4,"abab"); hm.put(3,"aba"); hm.put(3,"aba"); System.out.println(hm); HashMap hm=newhashmap(); hm.put(3,“aba”); hm.put(4,“abab”)
HashMap<Integer,String> hm=new HashMap();
hm.put(3,"aba");
hm.put(4,"abab");
hm.put(3,"aba");
hm.put(3,"aba");
System.out.println(hm);
HashMap hm=newhashmap();
hm.put(3,“aba”);
hm.put(4,“abab”);
hm.put(3,“aba”);
hm.put(3,“aba”);
系统输出打印项次(hm);
有没有办法在HashMap中保留副本?如果不是,如果我想这样做,我应该做什么(我应该使用什么接口或类?A
HashMap
不能有多个具有相同键的元素。尝试改用ArrayList
:
public class Item implements Comparable<Item>{
private int num;
private String name;
public Item(int num, String name) {
this.setNum(num);
this.setName(name);
}
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Item [num=" + num + ", name=" + name + "]";
}
@Override
public int compareTo(Item other) {
return this.num-other.num;
}
}
您并不是真正删除这些重复项,而是覆盖它们。如果您希望一个键具有多个不同的值,您可以创建一个Map
,例如。。。您想要的结果是什么样子的?Map
的关键是保留成对的键和值。如果每个键需要多个值,则地图条目必须包含一个集合
作为其值。预期结果:aba aba aba aba aba
,但我需要对key@Shoukhin78我用排序更新了答案
@Majed Badawi我想用hashmap解决codeforce中的一个问题。我想如果我使用你的方法,时间复杂度会增加,而且需要更多的内存。现在建议只使用列表还为时过早。我们不知道映射在一般应用程序中是如何使用的。@M.Prokhorov我们知道:“期望的结果:aba aba aba aba aba
但我需要对键进行排序”但是,它通常不会回答在映射中保留重复值的问题。@M.Prokhorov“不能有多个元素具有相同的键”@MajedBadawi,确切地说。这并不意味着您不能存储值或跟踪重复的数量,但在这种情况下,值将不是String
。
List<Item> list=new ArrayList<>();
list.add(new Item(3,"aba"));
list.add(new Item(4,"abab"));
list.add(new Item(3,"aba"));
list.add(new Item(3,"aba"));
Collections.sort(list);
System.out.println(list.toString());
[Item [num=3, name=aba], Item [num=3, name=aba], Item [num=3, name=aba], Item [num=4, name=abab]]