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 @   缤纷世界  阅读(24135)  评论(2编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
点击右上角即可分享
微信分享提示