两个List< string>比较是否相同的N种方法,你用过哪种?

今天在一技术群看一群大佬讨论:

有没有优雅的写法,比较两个List集合中的元素是不是完全一致…

在这里插入图片描述

站长最近也无聊,通过群里的聊天记录和给出的参考链接,简单做做总结,万一后面大家能用上呢?

我们做简单点,通过多种方式比较两个列表长度、所包含元素是否相等,不考虑顺序。

给出下面两个列表,按比较要求,两个列表是相等的:

List<string> lst1 = new List<string> { "2", "3", "1" };
List<string> lst2 = new List<string> { "1", "3", "2" };

方法一

由勤快哥给出的建议:排序后,通过string.join的方法转换为两个字符串后再比较,下面是代码:

Console.WriteLine("列表排序转换为字符串再比较");

lst1.Sort();
lst2.Sort();
var lstStr1 = string.Join(',',lst1);
var lstStr2 = string.Join(',', lst2);
bool isEquals = lstStr1.Equals(lstStr2);  // true

Console.WriteLine($"两者排序后通过(string.Join)转换为字符串:{isEquals}\r\n\r\n");

方法二和方法三由群里的tim大佬给的 stackoverflow 问题截图而来。

方法二

相较上面将列表转换字符串的方式,方法二简单点,排序后,使用SequenceEqual方法比较。

Console.WriteLine("使用Linq比较两个列表是否相等");
bool isEquals = Enumerable.SequenceEqual(lst1, lst2);  // false

Console.WriteLine($"两者直接通过(Enumerable.SequenceEqual(lst1, lst2))比较:{isEquals}");

// 1、集合排序再比较
lst1.Sort();
lst2.Sort(); 
isEquals = Enumerable.SequenceEqual(lst1, lst2);      // true

// 2、或者使用Linq的方式排序后再比较,一行代码的事儿
//isEquals = lst1.OrderBy(a => a).SequenceEqual(lst2.OrderBy(a=>a));  // true

Console.WriteLine($"两者排序后通过(Enumerable.SequenceEqual(lst1, lst2))比较:{isEquals}\r\n\r\n");

方法三

使用Lambda表达式,先取两列表的相同元素,然后将结果与列表1、列表2个数进行比较得到最终结果,代码如下:

Console.WriteLine("使用Lambda表达式比较两个列表是否相等");

var q = from a in lst1
        join b in lst2 on a equals b
        select a;

var isEquals = ((lst1.Count == lst2.Count) 
                && (q.Count() == lst1.Count));  // false,谢谢网友纠正

Console.WriteLine($"两者通过Lambda表达式比较:{isEquals}\r\n\r\n");

以上三种方法,都能得到最终比较结果,更多的方法,请查看下面由tim大佬搜索提供的链接:

https://stackoverflow.com/questions/649444/testing-equality-of-arrays-in-c-sharp

在这里插入图片描述

假设A和B类都有两个字段id和name,且id和name都是String类型。要找出List<A>和List<B>中id和name都相同的数据,并且这些数据在两个列表中的比例为N:M。 可以使用Java 8中的Stream API来实现: ``` import java.util.ArrayList; import java.util.Arrays; import java.util.List; import java.util.Map; import java.util.stream.Collectors; public class Main { public static void main(String[] args) { List<A> listA = Arrays.asList( new A("1", "John"), new A("2", "Mary"), new A("3", "Tom"), new A("4", "Lily"), new A("5", "Bob") ); List<B> listB = Arrays.asList( new B("1", "John"), new B("2", "Mary"), new B("4", "Lily"), new B("6", "Peter"), new B("7", "Alice"), new B("8", "Bob") ); int n = 3; int m = 2; Map<String, List<A>> mapA = listA.stream() .collect(Collectors.groupingBy(a -> a.getId() + "-" + a.getName())); Map<String, List<B>> mapB = listB.stream() .collect(Collectors.groupingBy(b -> b.getId() + "-" + b.getName())); List<A> resultA = new ArrayList<>(); List<B> resultB = new ArrayList<>(); mapA.forEach((key, valueA) -> { List<B> valueB = mapB.get(key); if (valueB != null && valueB.size() == n * valueA.size() / m) { resultA.addAll(valueA); resultB.addAll(valueB); } }); System.out.println("List<A>:"); resultA.forEach(System.out::println); System.out.println("List<B>:"); resultB.forEach(System.out::println); } } class A { private String id; private String name; public A(String id, String name) { this.id = id; this.name = name; } public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "A{" + "id='" + id + '\'' + ", name='" + name + '\'' + '}'; } } class B { private String id; private String name; public B(String id, String name) { this.id = id; this.name = name; } public String getId() { return id; } public void setId(String id) { this.id = id; } public String getName() { return name; } public void setName(String name) { this.name = name; } @Override public String toString() { return "B{" + "id='" + id + '\'' + ", name='" + name + '\'' + '}'; } } ``` 在这个例子中,先将List<A>和List<B>中的数据按照id和name合并成一个字符串作为Map的key,然后将List<A>和List<B>分别存储在两个Map中。接着遍历MapA,找到与之对应的MapB,如果MapB存在并且MapB中的数据数量符合比例N:M,则将这些数据加入到结果列表中。最后输出结果列表即可。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值