<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ù)的五種方式

          共 4711字,需瀏覽 10分鐘

           ·

          2021-03-17 20:20

          來自:CSDN,作者:多纖果凍

          鏈接:https://blog.csdn.net/qq_37939251/article/details/90713643

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

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

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

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

          Java示例使用LinkedHashSet刪除arraylist中的重復(fù)項(xiàng)。在給定的示例中,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進(jìn)行List去重

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

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

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

          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)); 
           } 

          獲取更多優(yōu)質(zhì)文章,點(diǎn)擊關(guān)注

          ??????

          瀏覽 71
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          評(píng)論
          圖片
          表情
          推薦
          點(diǎn)贊
          評(píng)論
          收藏
          分享

          手機(jī)掃一掃分享

          分享
          舉報(bào)
          <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>
                  先锋影音资源男人 | 黄色三级艹逼视频 | 千百撸日夜夜 | 国产精品亚洲专区在线播放麻豆 | 深夜福利久久 |