您好,登錄后才能下訂單哦!
這篇文章將為大家詳細(xì)講解有關(guān)Java如何實現(xiàn)對兩個List快速去重并排序操作,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
Java實現(xiàn)對兩個List快速去重并排序操作,具體如下:
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:去掉重復(fù)的后,相同的部分
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("初始數(shù)據(jù):" + list.toString()); //把list中的數(shù)據(jù)轉(zhuǎn)換成msp,去掉同一id值多余數(shù)據(jù),保留查找到第一個id值對應(yīng)的數(shù)據(jù) 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再轉(zhuǎn)換成list,就會得到根據(jù)某一字段去掉重復(fù)的數(shù)據(jù)的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("去掉重復(fù)數(shù)據(jù)后的數(shù)據(jù):" + listMap.toString()); } }
曾經(jīng)去某平安面試的時候面試官問的問題,當(dāng)時回答是冒泡循環(huán),哈哈,現(xiàn)在想想覺得好笑,跟冒泡循環(huán)個毛關(guān)系~~
切記,利用set的不重復(fù),可以快速去除重復(fù)
用一個List的某個屬性作為map的key,可以找到是否在list存在,這樣你就可以做響應(yīng)的處理
利用上面的demo,得到一個方案,解決下面的需求:
訂單中商品的集合如下:
退款中的商品集合如下:
那么其它的商品就應(yīng)該是XL:2件 M:2件
把其中一個list轉(zhuǎn)成map,然后在用第二個list中的相關(guān)屬性作為第一個map的key來判斷,最終問題得以引刃而解,哈哈,牛逼?。?/p>
//第一步:先將原始訂單中跟退款中一模一樣的移除出來 Map<String,Object> wsMap = new HashMap<String, Object>(); for (ApplyReturn applyReturn : groupItemList) { //格式itemId_color_size qua wsMap.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); } }
關(guān)于“Java如何實現(xiàn)對兩個List快速去重并排序操作”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。