溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

Java如何實現(xiàn)對兩個List快速去重并排序操作

發(fā)布時間:2021-04-15 13:54:31 來源:億速云 閱讀:197 作者:小新 欄目:編程語言

這篇文章將為大家詳細(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,得到一個方案,解決下面的需求:

訂單中商品的集合如下:

Java如何實現(xiàn)對兩個List快速去重并排序操作

退款中的商品集合如下:

Java如何實現(xiàn)對兩個List快速去重并排序操作

那么其它的商品就應(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é)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細(xì)節(jié)

免責(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)容。

AI