//比较两个String类型的List,返回不同的值
public static List getDiffrent(List list1, List list2){
Map<String,Integer> map = new HashMap<String,Integer>(list1.size()+list2.size());
List diff = new ArrayList();
List maxList = list1;
List minList = list2;
if(list2.size()>list1.size()){
maxList = list2;
minList = list1;
}
for (String string : maxList){
map.put(string, 1);
}
for (String string : minList){
Integer cc = map.get(string);
if(cc!=null){
map.put(string, ++cc);
continue;
}
map.put(string, 1);
}
for(Map.Entry<String, Integer> entry:map.entrySet()){
if(entry.getValue()==1)
{
diff.add(entry.getKey());
}
}
return diff;
}
该代码片段展示了一个Java方法,用于比较两个String类型的List,并返回只存在于其中一个List中的元素。首先,它创建一个HashMap来存储元素及其出现次数。然后,根据两个List的大小确定哪个是较大的List。接着,遍历较小的List,更新HashMap中的计数。最后,遍历HashMap,找出值为1的键(即只出现一次的元素),并将它们添加到结果List中。
1862

被折叠的 条评论
为什么被折叠?



