内容简介:翻译自:https://stackoverflow.com/questions/6680487/c-sharp-more-efficient-way-of-comparing-two-collections
我有两个系列
List<Car> currentCars = GetCurrentCars(); List<Car> newCars = GetNewCars();
我不想使用foreach循环或其他东西,因为我认为应该有更好的方法来做到这一点.
我正在寻找更有效的方法来比较这个集合并获得结果:
>在newCars中而不在currentCars中的汽车列表
>不在newCars和currentCars中的汽车列表
Type Car有int属性Id.
有一个答案,已经删除说
我的意思是说效率更高:更少的代码,更少的机制和更具可读性的案例
所以这样思考我的情况是什么?
什么是更少的代码,更少的机制,更可读的案例?
您可以使用以下情况:
var currentCarsNotInNewCars = currentCars.Except(newCars); var newCarsNotInCurrentCars = newCars.Except(currentCars);
但是,与foreach解决方案相比,这没有任何性能优势.它看起来更干净.
此外,请注意,您需要实现IEquatable<T>对于您的Car类,因此比较是在ID而不是在引用上完成的.
从表面上讲,更好的方法是不使用List<T>.但字典<TKey,TValue>以ID为关键:
var currentCarsDictionary = currentCars.ToDictionary(x => x.ID);
var newCarsDictionary = newCars.ToDictionary(x => x.ID);
var currentCarsNotInNewCars =
currentCarsDictionary.Where(x => !newCarsDictionary.ContainsKey(x.Key))
.Select(x => x.Value);
var newCarsNotInCurrentCars =
newCarsDictionary.Where(x => !currentCarsDictionary.ContainsKey(x.Key))
.Select(x => x.Value);
翻译自:https://stackoverflow.com/questions/6680487/c-sharp-more-efficient-way-of-comparing-two-collections
以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网
猜你喜欢:- 如何在Hibernate/JPA中配置具有两个连接池的两个数据源
- 如何合并两个 TensorFlow 模型
- 关于sqlmap的两个小坑
- JS计算两个时间间隔
- Scala 中的集合(二):集合性能比较
- Scala 中的集合(二):集合性能比较
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
算法设计与分析基础
Anany Levitin / 清华大学出版社 / 2007-11 / 59.00元
作者基于丰富的教学经验,开发了一套对算法进行分类的新方法。这套方法站在通用问题求解策略的高度,能对现有的大多数算法进行准确分类,从而使读者能够沿着一条清晰的、一致的、连贯的思路来探索算法设计与分析这一迷人领域。本书作为第2版,相对第1版增加了新的习题,还增加了“迭代改进”一章,使得原来的分类方法更加完善。 本书十分适合作为算法设计和分析的基础教材,也适合任何有兴趣探究算法奥秘的读者使用,只要......一起来看看 《算法设计与分析基础》 这本书的介绍吧!