Java尋找列表中的重複數據

一、尋找方法

在Java中,可以通過以下方法尋找列表中的重複數據:

public static <T> Set<T> findDuplicates(List<T> list) {
    final Set<T> setToReturn = new HashSet<T>();
    final Set<T> set1 = new HashSet<T>();
    for (T yourInt : list) {
        if (!set1.add(yourInt)) {
            setToReturn.add(yourInt);
        }
    }
    return setToReturn;
}

其中,在遍歷列表時,使用一個額外的HashSet記錄已經出現過的元素和還未出現過的元素。如果元素已經出現過一次,則它被加入到setToReturn中。最後返回setToReturn。

二、小標題2

1、可以使用Java8中的Stream API和Collectors.groupingBy()方法來尋找列表中的重複元素。

public static <T> Set<T> findDuplicates(List<T> list) {
    return list.stream()
            .collect(Collectors.groupingBy(Function.identity(),Collectors.counting()))
            .entrySet().stream()
            .filter(map -> map.getValue() > 1)
            .map(Map.Entry::getKey)
            .collect(Collectors.toSet());
}

首先,使用Collectors.groupingBy()方法基於元素group操作。然後,使用Collectors.counting()函數計算每個組中元素的數量。最後,使用filter()過濾大於1的元素,並將結果映射回原元素的列表。

2、在Java 8之前,可以使用HashMap來尋找列表中的重複元素。

public static <T> Set<T> findDuplicates(List<T> list) {
    final Set<T> setToReturn = new HashSet<T>();
    final Map<T, Integer> itemCountMap = new HashMap<T, Integer>();
    for (T item : list) {
        if (itemCountMap.containsKey(item)) {
            itemCountMap.put(item, itemCountMap.get(item) + 1);
            setToReturn.add(item);
        } else {
            itemCountMap.put(item, 1);
        }
    }
    return setToReturn;
}

在遍歷列表時,用一個Map來記錄每個元素出現的次數。如果元素已經出現過一次,則將其添加到setToReturn中,並且將其計數加1。否則,為元素計數設置值為1。

三、小標題3

1、可以使用Java 8中的Stream API和Collectors.collectingAndThen()方法來尋找列表中的重複元素。

public static <T> Set<T> findDuplicates(List<T> list) {
    final Set<T> seen = new HashSet<>();
    return list.stream()
            .filter(n -> !seen.add(n))
            .collect(Collectors.toCollection(LinkedHashSet::new));
}

LinkedHashSet用於保持元素的順序。在遍歷列表時,如果一個元素已經在seen集合中出現過,則將其添加到LinkedHashSet中。最後返回LinkedHashSet。

2、可以使用Java 8中的Stream API和Collectors.toMap()方法尋找列表中的重複元素。

public static <T> Set<T> findDuplicates(List<T> list) {
    final Set<T> uniques = new HashSet<>();
    return list.stream()
            .filter(n -> !uniques.add(n))
            .collect(Collectors.toMap(Function.identity(), v -> 1, (a, b) -> a + b))
            .entrySet().stream()
            .filter(map -> map.getValue() > 1)
            .map(Map.Entry::getKey)
            .collect(Collectors.toSet());
}

首先,使用filter排除重複元素。然後,使用toMap()方法將元素映射到其出現次數。最後,使用filter()過濾大於1的元素,並將結果映射回原元素的列表。

原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/247484.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
小藍的頭像小藍
上一篇 2024-12-12 13:21
下一篇 2024-12-12 13:21

相關推薦

  • Java JsonPath 效率優化指南

    本篇文章將深入探討Java JsonPath的效率問題,並提供一些優化方案。 一、JsonPath 簡介 JsonPath是一個可用於從JSON數據中獲取信息的庫。它提供了一種DS…

    編程 2025-04-29
  • java client.getacsresponse 編譯報錯解決方法

    java client.getacsresponse 編譯報錯是Java編程過程中常見的錯誤,常見的原因是代碼的語法錯誤、類庫依賴問題和編譯環境的配置問題。下面將從多個方面進行分析…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python讀取CSV數據畫散點圖

    本文將從以下方面詳細闡述Python讀取CSV文件並畫出散點圖的方法: 一、CSV文件介紹 CSV(Comma-Separated Values)即逗號分隔值,是一種存儲表格數據的…

    編程 2025-04-29
  • Java騰訊雲音視頻對接

    本文旨在從多個方面詳細闡述Java騰訊雲音視頻對接,提供完整的代碼示例。 一、騰訊雲音視頻介紹 騰訊雲音視頻服務(Cloud Tencent Real-Time Communica…

    編程 2025-04-29
  • Java Bean載入過程

    Java Bean載入過程涉及到類載入器、反射機制和Java虛擬機的執行過程。在本文中,將從這三個方面詳細闡述Java Bean載入的過程。 一、類載入器 類載入器是Java虛擬機…

    編程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介紹

    本文將詳細介紹Java Milvus SearchParam withoutFields的相關知識和用法。 一、什麼是Java Milvus SearchParam without…

    編程 2025-04-29
  • Python中讀入csv文件數據的方法用法介紹

    csv是一種常見的數據格式,通常用於存儲小型數據集。Python作為一種廣泛流行的編程語言,內置了許多操作csv文件的庫。本文將從多個方面詳細介紹Python讀入csv文件的方法。…

    編程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java語言中的一個版本,於2014年3月18日發布。本文將從多個方面對Java 8中某一周的周一進行詳細的闡述。 一、數組處理 Java 8新特性之一是Stream…

    編程 2025-04-29
  • Java判斷字元串是否存在多個

    本文將從以下幾個方面詳細闡述如何使用Java判斷一個字元串中是否存在多個指定字元: 一、字元串遍歷 字元串是Java編程中非常重要的一種數據類型。要判斷字元串中是否存在多個指定字元…

    編程 2025-04-29

發表回復

登錄後才能評論