<kbd id="afajh"><form id="afajh"></form></kbd>
<strong id="afajh"><dl id="afajh"></dl></strong>
    <del id="afajh"><form id="afajh"></form></del>
        1. <th id="afajh"><progress id="afajh"></progress></th>
          <b id="afajh"><abbr id="afajh"></abbr></b>
          <th id="afajh"><progress id="afajh"></progress></th>

          List 去除重復(fù)數(shù)據(jù)的五種方式,舒服~

          共 4816字,需瀏覽 10分鐘

           ·

          2021-07-06 13:48



          作者 | 多纖果凍

          來源 | csdn.net/qq_37939251/article/details/90713643

          以下介紹五種-不同的方法去除 Java 中ArrayList中的重復(fù)數(shù)據(jù)

          1.使用LinkedHashSet刪除arraylist中的重復(fù)數(shù)據(jù)

          LinkedHashSet是在一個ArrayList刪除重復(fù)數(shù)據(jù)的最佳方法。LinkedHashSet在內(nèi)部完成兩件事:

          • 刪除重復(fù)數(shù)據(jù)
          • 保持添加到其中的數(shù)據(jù)的順序

          Java示例使用LinkedHashSet刪除arraylist中的重復(fù)項。在給定的示例中,numbersList是包含整數(shù)的arraylist,其中一些是重復(fù)的數(shù)字,例如1,3和5.我們將列表添加到LinkedHashSet,然后將內(nèi)容返回到列表中。結(jié)果arraylist沒有重復(fù)的整數(shù)。

          import java.util.ArrayList;
          import java.util.Arrays;
          import java.util.LinkedHashSet;

          public class ArrayListExample
          {
              public static void main(String[] args)
              
              
          {

                  ArrayList<Integer> numbersList = new ArrayList<>(Arrays.asList(1123334566678));

                  System.out.println(numbersList);

                  LinkedHashSet<Integer> hashSet = new LinkedHashSet<>(numbersList);

                  ArrayList<Integer> listWithoutDuplicates = new ArrayList<>(hashSet);

                  System.out.println(listWithoutDuplicates);

              }

          }

          輸出結(jié)果

          [1, 1, 2, 3, 3, 3, 4, 5, 6, 6, 6, 7, 8]

          [1, 2, 3, 4, 5, 6, 7, 8]

          2.使用java8新特性stream進行List去重

          要從arraylist中刪除重復(fù)項,我們也可以使用java 8 stream api。使用steam的distinct()方法返回一個由不同數(shù)據(jù)組成的流,通過對象的equals() 方法進行比較。

          收集所有區(qū)域數(shù)據(jù)List使用Collectors.toList()

          Java程序,用于在不使用Set的情況下從java中的arraylist中刪除重復(fù)項。

          import java.util.ArrayList;
          import java.util.Arrays;
          import java.util.List;
          import java.util.stream.Collectors;

          public class ArrayListExample
          {
              public static void main(String[] args)
              
              
          {
              
                  ArrayList<Integer> numbersList = new ArrayList<>(Arrays.asList(1123334566678));

                  System.out.println(numbersList);

                  List<Integer> listWithoutDuplicates = numbersList.stream().distinct().collect(Collectors.toList());

                  System.out.println(listWithoutDuplicates);
                  
              }
              
          }

          輸出結(jié)果

          [1, 1, 2, 3, 3, 3, 4, 5, 6, 6, 6, 7, 8]

          [1, 2, 3, 4, 5, 6, 7, 8]

          3.利用HashSet不能添加重復(fù)數(shù)據(jù)的特性 由于HashSet不能保證添加順序,所以只能作為判斷條件保證順序:

          private static void removeDuplicate(List<String> list) {
              HashSet<String> set = new HashSet<String>(list.size());
              List<String> result = new ArrayList<String>(list.size());
              for (String str : list) {
                  if (set.add(str)) {
                      result.add(str);
                  }
              }
              list.clear();
              list.addAll(result);
          }

          4.利用List的contains方法循環(huán)遍歷,重新排序,只添加一次數(shù)據(jù),避免重復(fù):

          private static void removeDuplicate(List<String> list) {
              List<String> result = new ArrayList<String>(list.size());
              for (String str : list) {
                 if (!result.contains(str)) {
                     result.add(str);
                  }
              }
              list.clear();
              list.addAll(result);
          }

          5.雙重for循環(huán)去重

          for (int i = 0; i < list.size(); i++) { 
          for (int j = 0; j < list.size(); j++) { 
          if(i!=j&&list.get(i)==list.get(j)) { 
          list.remove(list.get(j)); 
           } 

          關(guān)注公眾號【Java技術(shù)江湖】后回復(fù)“PDF”即可領(lǐng)取200+頁的《Java工程師面試指南》

          強烈推薦,幾乎涵蓋所有Java工程師必知必會的知識點,不管是復(fù)習(xí)還是面試,都很實用。



          瀏覽 79
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          評論
          圖片
          表情
          推薦
          點贊
          評論
          收藏
          分享

          手機掃一掃分享

          分享
          舉報
          <kbd id="afajh"><form id="afajh"></form></kbd>
          <strong id="afajh"><dl id="afajh"></dl></strong>
            <del id="afajh"><form id="afajh"></form></del>
                1. <th id="afajh"><progress id="afajh"></progress></th>
                  <b id="afajh"><abbr id="afajh"></abbr></b>
                  <th id="afajh"><progress id="afajh"></progress></th>
                  高清无码免费观看 | 亚洲 日韩 中文字幕 | 91在线视频观看 | 色五月在线视频 | 青娱乐在线免费观看 |