如何从HashMAP计算相同的值?
HashMap<HashMap<String, Float>, String> HM=new HashMap<HashMap<String,Float>, String>();
HashMap<String, Float> h;
h=new HashMap<String, Float>();
h.put("X", 48.0f);
h.put("Y", 80.0f);
HM.put(typeValuesHM, "Red");
h=new HashMap<String, Float>();
h.put("X", 192.0f);
h.put("Y", 80.0f);
HM.put(typeValuesHM, "Red");
h=new HashMap<String, Float>();
h.put("X", 192.0f);
h.put("Y", 320.0f);
HM.put(typeValuesHM, "Blue");
h=new HashMap<String, Float>();
h.put("X", 336.0f);
h.put("Y", 560.0f);
HM.put(typeValuesHM, "Blue");
我的HashMap HM的值如下:
{ {x=48,y=80}=Red,{x=192,y=80}=Red,{x=192,y=320}=Blue,{x=336,y=560}=Blue }
下面,
我想计算HashMap HM中的相似值。
ie)如果我给出的值等于“红色”意味着我想得到count = 2。 如果我给值等于“蓝色”意味着我想得到数= 2。
如何从HashMAP HM计算相同的值?
答案 0 :(得分:11)
int count = Collections.frequency(new ArrayList<String>(HM.values()), "Red");
答案 1 :(得分:9)
循环进入条目集并将所有值放到第二个映射中,第一个映射值作为键,值将是计数:
Map<String, Integer> result = new TreeMap<String, Integer>();
for (Map.Entry<Map<String, Float>> entry:HM.entrySet()) {
String value = entry.getValue();
Integer count = result.get(value);
if (count == null)
result.put(value, new Integer(1));
else
result.put(value, new Integer(count+1));
}
示例的结果图应如下所示:
{"Red"=2, "Blue"=2} // values are stored as Integer objects
答案 2 :(得分:2)
你能做到的唯一方法是遍历所有元素并计算出现次数:
for(String value: hm.values()) {
if (value.equals(valueToCompare)) {
count++;
}
}
答案 3 :(得分:0)
int countValue(String toMatch) {
int count = 0;
for (String v : HM.values()) {
if (toMatch.equals(value)) {
count++;
}
}
return count;
}
此外,如果您只存储两个值,则使用HashMap
作为键可能有点过分。内置的Point
使用int
,但使用float
重新实现并不困难。
答案 4 :(得分:0)
Iterator<String> iter = HM.values().iterator();
while(iter.hasNext()) {
String color = iter.next();
if(color.equals("Red")) {
} else if(color.equals("Green")) {
} else if(color.equals("Blue")) {
}
}