java代码如下:
List list = new ArrayList<>();
Goods goods=new Goods("番茄炒鸡蛋",1,5.0,5.0);
Goods goods2=new Goods("红烧肉",1,10,10));
Goods goods3=new Goods("水煮活鱼",1,12,12));
Goods goods4=new Goods("番茄炒鸡蛋",1,5.0,5.0);
list.add(goods);
list.add(goods2);
list.add(goods3);
list.add(goods4);
实体类依次是菜名,数量,单价,总价;现在想将list中菜名相同的数据进行合并,并且数量和总价进行叠加.
考虑运行效率高点,尽量不要双层循环,要怎么实现?
一个关于List去重并叠加的问题
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- 打杂的程序员 2019-11-22 17:27关注
List<Goods> table; Map<String,Goods> map = new LinkedHashMap(); for (Goods good : list) { String key = good.get菜名; table = map.get(key); if (table != null) { table.set数量(table.get数量+ good.get数量); table.set单价(good.get单价); table.set总价(table.get总价+good.get总价); map.put(key, table); } else { map.put(key, good); } } for(Goods entry : map.values()){ newList.add(entry); }
用map 可以不用双循环,最后的newList是你最后返回的新的list。 全部手打,忘采纳
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 乘性高斯噪声在深度学习网络中的应用
- ¥15 运筹学排序问题中的在线排序
- ¥15 关于docker部署flink集成hadoop的yarn,请教个问题 flink启动yarn-session.sh连不上hadoop,这个整了好几天一直不行,求帮忙看一下怎么解决
- ¥30 求一段fortran代码用IVF编译运行的结果
- ¥15 深度学习根据CNN网络模型,搭建BP模型并训练MNIST数据集
- ¥15 C++ 头文件/宏冲突问题解决
- ¥15 用comsol模拟大气湍流通过底部加热(温度不同)的腔体
- ¥50 安卓adb backup备份子用户应用数据失败
- ¥20 有人能用聚类分析帮我分析一下文本内容嘛
- ¥30 python代码,帮调试,帮帮忙吧