使用Java判断集合中是否有重复值,若有重复,则输出这两个相同值对应的键

查找集合中所有相同的值,并输出所对应的键。(什么集合都可以)
例如:map集合中有如下几个元素
键:a1 值:qwe
键:a2 值:rty
键:a3 值:qwe
键:a4 值:uio
键:a5 值:pas
键:a6 值:pas

怎么判断值相同,并取出两个相同值所对应的键?(键值对是不固定的)

import java.io.ByteArrayOutputStream;
import java.io.PrintStream;
import java.util.HashSet;
import java.util.Map;
import java.util.Set;
import java.util.TreeMap;
import java.util.regex.Matcher;
import java.util.regex.Pattern;

public class SomeProgram {
public static void main(String[] args) {
Map<String, String> map = new TreeMap<String, String>();
map.put("a1", "qwe");
map.put("a2", "rty");
map.put("a3", "qwe");
map.put("a4", "uio");
map.put("a5", "pas");
map.put("a6", "pas");

ByteArrayOutputStream baos = new ByteArrayOutputStream();
PrintStream ps = new PrintStream(baos);
PrintStream old = System.out;
System.setOut(ps);
Set<String> set1 = new HashSet<String>();
Set<String> set2 = new HashSet<String>();
for (Map.Entry<String, String> entry : map.entrySet()) {
if (!set1.add(entry.getValue())) {
set2.add(entry.getValue());
}
System.out.print("key=" + entry.getKey() + ", value="
+ entry.getValue() + "\r\n");
}
ps.flush();
System.setOut(old);
String source = new String(baos.toByteArray());
String[] strs = set2.toArray(new String[set2.size()]);
for (String s : strs)
fetchSameKeyValuePair(source, s);
}

private static void fetchSameKeyValuePair(String source, String key) {
Pattern p = Pattern.compile("(key=[a-zA-Z0-9]*, value=" + key + ")");
Matcher m = p.matcher(source);
while (m.find()) {
System.out.println(m.group(1));
}
}
}追问

当集合数据量大的时候就没数据了。

追答

多大?

追问

518KB,就是把集合写成文件的大小

追答

把实际文件的内容(十行左右)复制上来看看(截图也行),我帮你想个对策。
不过要等我下班。

温馨提示:答案为网友推荐,仅供参考
第1个回答  2012-05-02
用正则表达式啊,或者使用String类提供的方法。
相似回答