JAVA获取两个List<String>中不同的数据

效率非常不错

测试结果:

1、list1中有97277条数据,list2中有37894条数据,两个list进行对比找出不同的数据共60000条左右,用时:0.051秒

2、list1中有97277条数据,list2中有97067条数据,两个list进行对比找出不同的数据共288条,用时:0.06秒

下面的方法是对比两个list相互不同的数据

也可以删除红色字的代码做成list1比list2多出多少数据

public static List<String> getDiffrent4(List<String> list1, List<String> list2) 
    {           
           Map<String,Integer> map = new HashMap<String,Integer>(list1.size()+list2.size());
           List<String> diff = new ArrayList<String>();
           List<String> maxList = list1;
           List<String> 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;                    
    }

 

posted @ 2013-07-12 15:16  缤纷世界  阅读(24067)  评论(2编辑  收藏  举报