Java List中按要求去除对象某个字段的重复值

SoulOH 2018-06-30 05:47:23
需求:List<networkNode> list放了一些对象:node0, node1, node2, node3, node4 ……
networkNode有3个属性id, destip, delay:
这一些node中有destip重复的对象,对于这些重复的对象,需要只保留delay最小的那个
例:node0的记录:“192,168,1,1”, 30;
node1的记录:“192.168.1.2”, 20;
node2的记录:“192.168.1.1“, 15;
node0和node2的destip重复,然而node0.delay > node2.delay,需要去掉node0,保留node2。
(实际需求中,node4,node5……可能还有重复)
结果仍保留在原list中。

ps:百度上找到的都是直接把重复的对象去除,但是这里不能任意去除。
...全文
2489 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
_jant 2018-07-02
  • 打赏
  • 举报
回复
兄弟 你按照delay从小到大排序,然后把你的那个实体放入 HashMap中,key是ip,value是实体, 如果发现key重复你就不要加进去了。能加进去的肯定都是delay最小的。 然后再把map转List不就好了?
maradona1984 2018-07-02
  • 打赏
  • 举报
回复
引用 4 楼 SoulOH 的回复:
[quote=引用 1 楼 verejava 的回复:]
for(int i=list.size()-1;i>=0;i--)
{
NetworkNode networkNodei=list.get(i);
for(int j=list.size()-1;j>=0;j--)
{
NetworkNode networkNodej=list.get(j);
if(networkNodei.delay > networkNodej.delay)
{
list.remove(j);
}
}
}


不知道为什么,我试了一下,结果却是
Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 1, Size: 1
at java.util.LinkedList.checkElementIndex(LinkedList.java:555)
at java.util.LinkedList.get(LinkedList.java:476)
at Main.main(Main.java:15)
[/quote]

这代码看一下就知道错的
weixin_40852944 2018-07-02
  • 打赏
  • 举报
回复

Map<String, NetworkNode> map = new HashMap<>();
for (NetworkNode networkNode : list) {
String destip = networkNode.getDestip();
if (map.containsKey(destip)) {
Integer delay = map.get(destip).getDelay();
if (delay < networkNode.getDelay()) {
continue;
}
}
map.put(destip, networkNode);
}
list = new ArrayList<>(map.values());
  • 打赏
  • 举报
回复

public static List<networkNode> removeDuplicteObjects(List<networkNode> nodes) {
List<networkNode> new_nodes = new ArrayList<networkNode>();
for(networkNode node: nodes){
boolean exsist = false;
for(networkNode new_node:new_nodes){
if(node.getDestip().equals(new_node.getDestip())){
if(node.getDelay() < new_node.getDelay()){
new_nodes.set(new_nodes.indexOf(new_node), node);
}
exsist = true;
break;
}
}
if(!exsist){
new_nodes.add(node);
}
}
return new_nodes;
}
oyljerry 2018-07-01
  • 打赏
  • 举报
回复
用一个hashmap,IP做key,分数做值。遍历list,查看当前节点的分数是否最小,不是就删除当前节点。否则更新hashmap
SoulOH 2018-07-01
  • 打赏
  • 举报
回复
引用 3 楼 oyljerry 的回复:
遍历list,查看当前节点的分数是否最小,不是就删除当前节点。否则更新hashmap


? 没有看懂?destip不一样的节点是不能删掉的。请问你知道具体的实现吗?
SoulOH 2018-07-01
  • 打赏
  • 举报
回复
引用 1 楼 verejava 的回复:
for(int i=list.size()-1;i>=0;i--)
{
NetworkNode networkNodei=list.get(i);
for(int j=list.size()-1;j>=0;j--)
{
NetworkNode networkNodej=list.get(j);
if(networkNodei.delay > networkNodej.delay)
{
list.remove(j);
}
}
}


不知道为什么,我试了一下,结果却是
Exception in thread "main" java.lang.IndexOutOfBoundsException: Index: 1, Size: 1
at java.util.LinkedList.checkElementIndex(LinkedList.java:555)
at java.util.LinkedList.get(LinkedList.java:476)
at Main.main(Main.java:15)
verejava 2018-07-01
  • 打赏
  • 举报
回复

for(int i=list.size()-1;i>=0;i--)
{
NetworkNode networkNodei=list.get(i);
for(int j=list.size()-1;j>=0;j--)
{
NetworkNode networkNodej=list.get(j);
if(networkNodei.delay > networkNodej.delay)
{
list.remove(j);
}
}
}
verejava 2018-07-01
  • 打赏
  • 举报
回复
for(int i=list.size()-1;i>=0;i--)
{
NetworkNode networkNodei=list.get(i);
for(int j=list.size()-1;j>=0;j--)
{
NetworkNode networkNodej=list.get(j);
if(networkNodei.delay > networkNodej.delay)
{
list.remove(j);
}
}
}


该课程由付强老师主讲,系统的、全面的、具体的讲解了java入门的知识。可以使初级的学员入门。Java入门Java的历史、Java的版本、Java的优势、软件行业前景Java开发环境搭建、编写Java入门练习虚拟机的运行机制、Java的平台无关性、虚拟机垃圾回收机制基础语法关键字、标识符、Java数据类型分类、基础数据类型、取范围变量、常量、三种注释、生成doc文档、运算符、表达式if语句、switch语句、嵌套判断for语句、while语句、do-while语句、嵌套循环类和对象面向过程和面向对象的区别类的构成、访问修饰符、对象的内存分配this关键字、按传递与按引用传递、对象的初始化顺序高级类特性类的继承、父子类的初始化顺序、单继承性方法的覆盖、重载、super关键字、多态、instanceof关键字、强制类型转换、static关键字、final关键字数组和枚举一维数组的应用及内存分配多维数组的应用及内存分配数组的复制、数组的按引用传递排序算法:冒泡、直接选择、插入选择、希尔、快速、归并、堆排序Arrays工具类的应用枚举类型的应用常见类的使用Object类的底层及应用、Objects类String类的底层及应用、正则表达式StringBuffer和StringBuilder的底层及应用Math类的应用、包装类的应用日期类的应用:Date、DateFormat、Calendar、LocalDateTime、Instant、LocalDate、MonthDay、ZonedDateTime、YearMonth、新旧日期转换BigInteger和BingDecimal、DecimalFormatSystem类、Scanner类抽象类和接口抽象类的规则及应用接口的规则及应用默认方法、静态方法、函数式接口、Lambda表达式异常异常的定义异常的处理:抓(try-catch-finally)、抛(throws)异常的分类、自定义异常的应用、throw关键字集合框架集合框架结构:接口、实现类Collection接口的方法、Set接口的方法、List接口的方法、Map接口的方法Array、Linked、Hash、Tree底层实现原理泛型的作用、Collections工具类、历史集合类I/O流Path类的原理及应用、Files类的原理及应用文件字节流FileInputStream的原理及应用对象类、缓冲流、数据流的原理及应用字符流的原理及应用多线程进程与线程的概念、查看线程对象Java内存模型线程的创建与启动:扩展Thread类、实现Runnable接口、实现Callable接口、线程池线程状态的转换:新建、就绪、运行、阻塞、死亡线程的调度:sleep、yield、join、interrupt、wait后台线程、定时任务线程的并发与同步、同步锁、同步块、线程安全的类Lock接口、CAS、volatile修饰符内部类成员内部类、本地内部类的应用匿名内部类的原理及引用、Lambda表达式设计模式基础设计模式概念、框架概念7大设计原则:开闭原则、依赖倒置原则、单一职责原则、接口隔离原则、迪米特原则、里氏替换原则、合成复用原则单例模式、工厂模式、模板模式、代理模式、装饰模式、适配器模式、外观模式、策略模式、观察者模式、命令模式、备忘录模式、观察者模式反射反射包Class类的使用反射获取类属性、方法、构造器通过反射创建类对象/通过反射调用方法反射的应用

62,614

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧