java对List去重并排序、如何快速地去掉两个List中相同的部分
来源:互联网 发布:sql界面 编辑:程序博客网 时间:2024/05/16 02:22
1:去重并排序
package twolist;import java.util.Collections; import java.util.Comparator; import java.util.HashMap; import java.util.HashSet; import java.util.LinkedList; import java.util.List; import java.util.Map; import java.util.Set;public class ListMapSort { /** * @param args */ public static void main(String[] args) { // TODO 自动生成方法存根 List<Map<String,Object>> listMap1 = new LinkedList<Map<String,Object>>(); Map<String,Object> map = new HashMap<String, Object>(); map.put("date", 20121010); listMap1.add(map); map = new HashMap<String, Object>(); map.put("date", 20011213); listMap1.add(map); listMap1.add(map); map = new HashMap<String, Object>(); map.put("date", 20130502); listMap1.add(map); System.out.println("原始"+listMap1); List<Map<String,Object>> listMap2 = new LinkedList<Map<String,Object>>(); Set<Map> setMap = new HashSet<Map>(); for(Map<String,Object> map1 : listMap1){ if(setMap.add(map1)){ listMap2.add(map1); } } System.out.println("去重"+listMap2); Collections.sort(listMap2, new Comparator<Map<String,Object>>(){ public int compare(Map<String,Object> o1,Map<String,Object> o2){ return o1.get("date").toString().compareTo(o2.get("date").toString()); } }); System.out.println("排序:"+listMap2); } }
2:去掉重复的后,相同的部分
package twolist;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import java.util.Set;public class RemoveList {private <K, V> void cleanListByMapKey(List<Map<K,V>> list, K toBeRemoved) { List<Map<K,V>> tmpList=new ArrayList<>(); for(Map<K,V> m: list){ if(m.containsKey(toBeRemoved)) tmpList.add(m); } list.removeAll(tmpList);} public void testCleanListByMapKey(){ List<Map<String,String>> list=new ArrayList<>(); for(int i=0;i<10;i++){ Map<String, String> m=new HashMap<>(); m.put("key"+i, "value"+i); list.add(m); } Map<String, String> m=new HashMap<>(); m.put("key100", "value100"); list.add(m); System.out.println(list.contains(m)); cleanListByMapKey(list, "key100"); System.out.println(list.contains(m));}public static void main(String[] args) {/*RemoveList remove = new RemoveList();remove.testCleanListByMapKey();*/// TODO Auto-generated method stub Map<String, Map> msp = new HashMap<String, Map>(); List<Map<String, Object>> list = new ArrayList<Map<String, Object>>(); List<Map<String, Object>> listMap = new ArrayList<Map<String,Object>>(); Map<String, Object> map1 = new HashMap<String, Object>(); map1.put("id", "1"); map1.put("name", "p"); Map<String, Object> map2 = new HashMap<String, Object>(); map2.put("id", "3"); map2.put("name", "h"); Map<String, Object> map3 = new HashMap<String, Object>(); map3.put("id", "3"); map3.put("name", "f"); list.add(map1); list.add(map3); list.add(map2); System.out.println("初始数据:" + list.toString()); //把list中的数据转换成msp,去掉同一id值多余数据,保留查找到第一个id值对应的数据 for(int i = list.size()-1 ; i>=0; i--){ Map map = list.get(i); String id = (String)map.get("id"); map.remove("id"); msp.put(id, map); } //把msp再转换成list,就会得到根据某一字段去掉重复的数据的List<Map> Set<String> mspKey = msp.keySet(); for(String key: mspKey){ Map newMap = msp.get(key); newMap.put("id", key); listMap.add(newMap); } System.out.println("去掉重复数据后的数据:" + listMap.toString());}}
曾经去某平安面试的时候面试官问的问题,当时回答是冒泡循环,哈哈,现在想想觉得好笑,跟冒泡循环个毛关系~~
切记,利用set的不重复,可以快速去除重复
用一个List的某个属性作为map的key,可以找到是否在list存在,这样你就可以做响应的处理
利用上面的demo,得到一个方案,解决下面的需求:
订单中商品的集合如下:
退款中的商品集合如下:
那么其它的商品就应该是XL:2件 M:2件
把其中一个list转成map,然后在用第二个list中的相关属性作为第一个map的key来判断,最终问题得以引刃而解,哈哈,牛逼!!
//【猥琐】第一步:先将原始订单中跟退款中一模一样的移除出来Map<String,Object> wsMap = new HashMap<String, Object>(); for (ApplyReturn applyReturn : groupItemList) {//格式itemId_color_size quawsMap.put(applyReturn.getItemId()+"_"+applyReturn.getColor()+"_"+applyReturn.getSize(), applyReturn.getQua());}List<OrderDetail> newListOrderDetails = new ArrayList<OrderDetail>();List<OrderDetail> listOrderDetail = order.getDetails();//第二步:再来遍历剩下的int mapQua = 0;for (OrderDetail orderDetail : listOrderDetail) {if(wsMap.get(orderDetail.getTid()+"_"+orderDetail.getKcolor()+"_"+orderDetail.getKsize())!=null){mapQua = Integer.parseInt(wsMap.get(orderDetail.getTid()+"_"+orderDetail.getKcolor()+"_"+orderDetail.getKsize()).toString());if(mapQua<orderDetail.getQua()){OrderDetail newOrderDetail = orderDetail;newOrderDetail.setQua(orderDetail.getQua()-mapQua);newListOrderDetails.add(newOrderDetail);}}else{newListOrderDetails.add(orderDetail);}}
0 1
- java对List去重并排序、如何快速地去掉两个List中相同的部分
- python进阶指南:list如何去重(去掉list中元素为字典的且字典部分key相同的list元素)
- 两个List合并去重,并排序
- java 合并两个list 并去重
- 得到两个list中相同的部分。
- 对list对象进行去重操作,并排序
- 快速得到两个list中不同部分的list
- java中关于List的去重
- java 两个相同元素的List,合并排序去除重复元素的快速算法
- list 对象去重并排序
- Python快速查找list中相同部分
- java中List去重
- Java中List去重
- list排序,list去重
- list去重排序
- List排序去重
- List去重排序
- java中如何对list进行排序
- CommDateUtil
- python学习08-错误和异常
- iOS开发之圆形进度条
- Log4j日志等级
- 最小费用最大流
- java对List去重并排序、如何快速地去掉两个List中相同的部分
- Linux 下十大命令行下载工具
- ajax
- Umm 类图关系总结
- chm内容显示为空白的处理方法
- 资深C++程序员学习C#要点
- Cocos2dx 2.x移植安卓及打包
- (4.1.20.2)Android 5.0 可以给一个 View 单独设置一个 theme
- 一个介绍android 的log的一些进一步封装与快捷操作的文章