Java 集合有序性與重復性總結及記憶技巧

Java 集合有序性與重復性總結及記憶技巧

一、集合分類速查表

集合類型是否有序是否允許重復記憶口訣
ArrayList? 有序(插入順序)? 可重復"數組列表,順序記牢"
LinkedList? 有序(插入順序)? 可重復"鏈表結構,先來后到"
HashSet? 無序(插入時沒有順序)? 不可重復"哈希散列,亂序唯一"
LinkedHashSet? 有序(插入順序)? 不可重復"鏈表哈希,有序唯一"
TreeSet? 有序(自然/定制排序)? 不可重復"樹形排序,規則唯一"
HashMap? 無序Key不可重復"哈希大哥,亂序當家"
LinkedHashMap? 有序(插入/訪問順序)Key不可重復"鏈表哈希,順序鑰匙"
TreeMap? 有序(Key排序)Key不可重復"樹形鑰匙,排隊進門"
ArrayDeque? 有序(隊列/棧順序)? 可重復"雙端隊列,先進先出"

二、記憶方法大全

1. 按數據結構記憶

  • 數組/鏈表結構(ArrayList/LinkedList/ArrayDeque):
    →?有序 + 可重復(像排隊,先來后到,可以有人同名)

  • 哈希表結構(HashSet/HashMap):
    →?無序 + 不可重復(像丟進桶里的球,亂序且唯一)

  • 鏈表+哈希組合(LinkedHashSet/LinkedHashMap):
    →?有序 + 不可重復(用鏈表記錄順序,但內容唯一)

  • 樹形結構(TreeSet/TreeMap):
    →?排序 + 不可重復(像字典,按字母排序且單詞唯一)

2. 命名規律記憶

  • 帶"Linked":有序(插入順序)
    LinkedHashSetLinkedHashMap

  • 帶"Tree":排序(自然/定制順序)
    TreeSetTreeMap

  • 純"Hash":無序
    HashSetHashMap

  • 帶"List":有序+可重復
    ArrayListLinkedList

3. 生活場景聯想

  • ArrayList?→?班級點名冊
    (按學號順序記錄,允許同名同姓)

  • HashSet?→?抽獎箱
    (名字丟進去亂序混合,但每人只能中獎一次)

  • TreeSet?→?字典目錄
    (按字母排序,每個單詞唯一)

  • LinkedHashMap?→?餐廳排隊系統
    (按排隊順序叫號,但每個號碼唯一)


三、面試高頻問題

1. 如何選擇集合?

  • 需要快速訪問且不關心順序? →?HashMap/HashSet

  • 需要保持插入順序? →?LinkedHashMap/LinkedHashSet

  • 需要自動排序? →?TreeMap/TreeSet

  • 需要允許重復? →?ArrayList/LinkedList

2. 為什么Set不允許重復?

  • 底層用Map實現(如HashSet用HashMap),重復元素會被覆蓋

    java

// HashSet的add方法源碼
public boolean add(E e) {return map.put(e, PRESENT) == null; // 用HashMap的key去重
}

3. 如何讓List去重?

  • 轉換為Set:

    java

    List<String> list = new ArrayList<>();
    Set<String> set = new LinkedHashSet<>(list); // 保留順序去重


四、總結圖示

mermaid

pietitle 集合特性占比"有序+可重復" : 3 (ArrayList/LinkedList/ArrayDeque)"有序+不可重復" : 3 (LinkedHashSet/TreeSet/LinkedHashMap/TreeMap)"無序+不可重復" : 2 (HashSet/HashMap)

一句話總結
"數組鏈表可重復,哈希亂序需唯一,帶Link保順序,帶Tree會排序"

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/76018.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/76018.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/76018.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

記錄學習的第二十三天

老樣子&#xff0c;每日一題開胃。 我一開始還想著暴力解一下試試呢&#xff0c;結果不太行&#x1f602; 接著兩道動態規劃。 這道題我本來是想用最長遞增子序列來做的&#xff0c;不過實在是太麻煩了&#xff0c;實在做不下去了。 然后看了題解&#xff0c;發現可以倒著數。 …

MTK-Android12-13 屏幕永不休眠功能實現

MTK-Android12-13 屏幕永不休眠功能實現 文章目錄 需求場景參考資料修改文件簡要分析實現方案默認休眠時間設置 def_screen_off_timeout息屏時間添加永不休眠 screen_timeout_entries更新休眠時間 updateUserActivitySummaryLocked 總結 需求 屏幕永不休眠功能 備注&#xff…

Lua 中,`math.random` 的詳細用法

在 Lua 中&#xff0c;math.random 是用于生成偽隨機數的核心函數。以下是其詳細用法、注意事項及常見問題的解決方案&#xff1a; Lua 中&#xff0c;math.random 的詳細用法—目錄 一、基礎用法1. 生成隨機浮點數&#xff08;0 ≤ x < 1&#xff09;2. 生成指定范圍的隨機…

HOW - React Error Catch 機制

目錄 1. 錯誤邊界&#xff08;Error Boundaries&#xff09;使用場景寫法&#xff08;類組件方式&#xff09;&#xff1a;componentDidCatch 2. 事件處理器中的錯誤3. 異步函數中的錯誤&#xff08;如 fetch、Promise&#xff09;4. 全局未捕獲錯誤&#xff08;適用于整個 Rea…

1.ElasticSearch-入門基礎操作

一、介紹 The Elastic Stack 包含ElasticSearch、Kibana、Beats、LogStash 這就是所說的ELK 能夠安全可靠地獲取任何來源、任何格式的數據&#xff0c;然后實時地對數據進行搜索、分析和可視化。Elaticsearch,簡稱為ES&#xff0c;ES是一個開源的高擴展的分布式全文搜索引擎,是…

通過扣子平臺將數據寫入飛書多維表格

目錄 1.1 創建飛書開放平臺應用 1.2 創建飛書多維表格 1.3 創建扣子平臺插件 1.1 創建飛書開放平臺應用 1.1.1 打開地址&#xff1a;飛書開放平臺&#xff0c;點擊創建應用 注&#xff1a;商店應用需要申請ISV資質&#xff0c;填寫企業主體信息&#xff0c;個人的話&#x…

MYSQL數據庫語法補充

一&#xff0c;DQL基礎查詢 DQL&#xff08;Data Query Language&#xff09;數據查詢語言&#xff0c;可以單表查詢&#xff0c;也可以多表查詢 語法&#xff1a; select 查詢結果 from 表名 where 條件&#xff1b; 特點&#xff1a; 查詢結果可以是&#xff1a;表中的字段…

Redis到底能不能做主數據庫?

張三拍案而起&#xff1a;“Redis 是緩存數據庫&#xff0c;怎么能當主數據庫用&#xff1f;簡直是天方夜譚&#xff01;” 李四冷笑回應&#xff1a;“你沒用過&#xff0c;憑什么說不行&#xff1f;我已經用 Redis 做主數據庫好幾年了&#xff0c;系統穩定得像鐵板一塊&…

flutter 項目結構目錄以及pubspec.ymal等文件描述

在Flutter項目中&#xff0c;目錄結構和pubspec.yaml文件是非常重要的組成部分&#xff0c;它們定義了項目的結構、依賴管理以及如何構建和運行項目。下面我將詳細解釋這些關鍵元素&#xff1a; 1. Flutter項目目錄結構 Flutter項目的標準目錄結構通常如下所示&#xff1a; …

CentOS 環境下 MySQL 數據庫全部備份的操作指南

最近阿里云個人服務到期&#xff0c;因為是很久之前買的測試機器&#xff0c;配置較低&#xff0c;上面運行的有技術博客 和以往的測試項目&#xff0c;所以準備放棄掉。 需要備份下上面的表結構和數據、以及代碼倉庫。 下面是一個完整的 CentOS 環境下 MySQL 數據庫全部備份…

ecplise 工具 沒有Java EE Tools 選項

Java EE Tools 是將項目轉換為web項目的重要的快捷鍵&#xff0c;如果進行web開發 那是不可或缺的 該工具是一個插件&#xff0c;可以作為插件安裝到ecplise上 安裝步驟如下&#xff1a; 找到help-->install new software 在彈出的頁面中 work with中輸入&#xff1a;Jun…

544 eff.c 1761 優化設計文檔

1:性能分析 1.1性能對比 oneapi 與hygonGcc性能對比發現&#xff0c;544課題中的eff.c 1761循環處&#xff0c;oneapi 進行了循環向量化, gcc使用標量&#xff0c;循環源碼前加 #pragma clang loop vectorize(disable) 找出oneapi在該循環處關閉和開啟loop vect 的性能差距&a…

LeetCode.3396.使數組元素互不相同所需的最少操作次數

3396. 使數組元素互不相同所需的最少操作次數 給你一個整數數組 nums&#xff0c;你需要確保數組中的元素 互不相同 。為此&#xff0c;你可以執行以下操作任意次&#xff1a; 從數組的開頭移除 3 個元素。如果數組中元素少于 3 個&#xff0c;則移除所有剩余元素。 注意&…

【已完結STM32】--自學江協科技筆記匯總

以下學習筆記代碼均來自b站江協科技視頻 筆記匯總完結 文章筆記對應江科大視頻新建工程【2-2】新建工程江科大STM32-GPIO輸出 點亮LED&#xff0c;LED閃爍&#xff0c;LED流水燈&#xff0c;蜂鳴器&#xff08;學習筆記&#xff09;_unit32-t rcc-apb2periph-CSDN博客 【3-1】…

QML Loader:加載組件與狀態監控

目錄 引言相關閱讀工程結構示例一&#xff1a;從文件加載組件 (LoaderFile.qml)代碼實現被加載的組件&#xff1a;MyComponent.qml代碼解析運行效果 示例二&#xff1a;直接加載Component對象 (LoaderComponent.qml)代碼實現代碼解析運行效果 示例三&#xff1a;監控加載狀態 (…

K8S核心技術點

Pod&#xff0c;Service和Deployment的關系 Pod&#xff1a;Kubernetes 中最小的部署單元&#xff0c;用于運行容器化應用。 Service&#xff1a;提供服務發現和負載均衡&#xff0c;為 Pod 提供穩定的網絡端點&#xff0c;ClusterIP&#xff0c;NodePort&#xff0c;LoadBala…

Spring 核心注解深度解析:@Autowired、@Repository 與它們的協作關系

引言 在 Spring 框架中&#xff0c;?依賴注入&#xff08;DI&#xff09;?? 是實現松耦合架構的核心機制。Autowired 和 Repository 作為兩個高頻使用的注解&#xff0c;分別承擔著 ?依賴裝配? 和 ?數據訪問層標識? 的關鍵職責。本文將深入探討它們的功能特性、協作模式…

[Linux]從零開始的ARM Linux交叉編譯與.so文件鏈接教程

一、前言 最近在項目需要將C版本的opencv集成到原本的代碼中從而進行一些簡單的圖像處理。但是在這其中遇到了一些問題&#xff0c;首先就是原本的opencv我們需要在x86的架構上進行編譯然后將其集成到我們的項目中&#xff0c;這里我們到底應該將opencv編譯為x86架構的還是編譯…

svelte+vite+ts+melt-ui從0到1完整框架搭建

框架太“重”了&#xff1a;通常一個小型項目只由少數幾個簡單頁面構成&#xff0c;如果使用 Vue 或者 React 這些框架來研發的話&#xff0c;有點“大材小用”了。構建的產物中包含了不少框架運行時代碼(虛擬 DOM、響應式、狀態管理等)&#xff0c;這些代碼對于小型項目而言是…

無法看到新安裝的 JDK 17

在 Linux 系統中使用 update-alternatives --config java 無法看到新安裝的 JDK 17&#xff0c;可能是由于 JDK 未正確注冊到系統備選列表中。 一、原因分析 JDK 未注冊到 update-alternatives update-alternatives 工具需要手動注冊 JDK 路徑后才能識別新版本。如果僅安裝 JDK…