Finding duplicate values in arraylist(在arraylist中查找重复值)
问题描述
我有一个 ArrayList<Car>
举例
class Car{
String carName;
int carType;
}
现在,我必须查找列表中是否有任何具有相同名称的汽车.最好的方法是什么?
Now, I have to find if the list has any cars having same name. What is the best way to do this?
推荐答案
创建比较器:
public class CarComparator implements Comparator<Car>
{
public int compare(Car c1, Car c2)
{
return c1.carName.compareTo(c2.carName);
}
}
现在将 ArrayList 的所有汽车添加到 SortedSet,最好是 TreeSet;如果有重复项添加到重复项列表中:
Now add all the cars of the ArrayList to a SortedSet, preferably TreeSet; if there are duplicates add to the list of duplicates:
List<Car> duplicates = new ArrayList<Car>();
Set<Car> carSet = new TreeSet<Car>(new CarComparator());
for(Car c : originalCarList)
{
if(!carSet.add(c))
{
duplicates.add(c);
}
}
最后,在您的 duplicates 中,您将拥有所有重复项.
Finally in your duplicates you will have all the duplicates.
这篇关于在arraylist中查找重复值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:在arraylist中查找重复值
基础教程推荐
- 在java中使用xpath和selenium解析HTML表格数据 2022-01-01
- Java ECDSAwithSHA256 签名长度不一致 2022-01-01
- Maven:无效的目标版本:10 2022-01-01
- 控制台应用程序中的 Java 键盘输入解析 2022-01-01
- doFilter()是在servlet的工作完成之前还是之后执行的? 2022-01-01
- 将 Windows 证书导入 Java 2022-01-01
- JPA惰性列表上的流 2022-01-01
- 在springboot中如何给mybatis加拦截器 2023-04-29
- 如何在相机中应用自定义滤镜 [Surfaceview 预览]. 2022-01-01
- 将 double 转换为 Int,向下舍入 2022-01-01
