【每日算法】Day 6-1:哈希表從入門到實戰——高頻算法題(C++實現)

摘要 :掌握高頻數據結構!今日深入解析哈希表的核心原理與設計實現,結合沖突解決策略與大廠高頻真題,徹底掌握O(1)時間復雜度的數據訪問技術。

一、哈希表核心思想

哈希表(Hash Table) 是一種基于鍵值對的高效數據結構,通過哈希函數將鍵映射到存儲位置,核心特性:

  • 平均時間復雜度:插入、刪除、查找均為O(1)

  • 沖突處理:開放尋址法、鏈地址法等策略

  • 負載因子:哈希表性能的關鍵指標(元素數/桶數)

應用場景

  • 快速數據檢索

  • 去重操作

  • 緩存系統設計(如LRU Cache)

二、哈希表實現原理

1. 哈希函數設計

理想哈希函數特性

  • 確定性:相同鍵的哈希值始終相同

  • 均勻性:鍵值均勻分布到各個桶

  • 高效性:計算速度快

常見哈希函數

  • 除法哈希:hash(key) = key % capacity

  • 乘法哈希:利用黃金分割點

  • 多項式哈希:用于字符串處理

// 字符串哈希示例(多項式滾動哈希)
size_t stringHash(const string& s, size_t mod = 1e9+7) {size_t hash = 0;const size_t base = 31; // 常用質數基數for (char c : s) {hash = (hash * base + c) % mod;}return hash;
}

2. 沖突解決策略

動態示意圖

鏈地址法示意圖

策略1:鏈地址法(Separate Chaining)

// 哈希表節點定義
template <typename K, typename V>
struct HashNode {K key;V value;HashNode* next;HashNode(K k, V v) : key(k), value(v), next(nullptr) {}
};// 哈希表類框架
template <typename K, typename V>
class HashMap {
private:vector<HashNode<K,V>*> buckets;size_t capacity;size_t size;size_t hashFunction(K key) {return hash<K>{}(key) % capacity;}public:HashMap(size_t cap = 16) : capacity(cap), size(0) {buckets.resize(cap, nullptr);}// 插入、查找、刪除操作實現...
};

策略2:開放尋址法(Open Addressing)

// 線性探測插入實現
template <typename K, typename V>
void HashMap<K,V>::put(K key, V value) {size_t index = hashFunction(key);while (buckets[index] != nullptr) {if (buckets[index]->key == key) { // 已存在則更新buckets[index]->value = value;return;}index = (index + 1) % capacity; // 線性探測}buckets[index] = new HashNode<K,V>(key, value);size++;
}

三、哈希表操作實現(C++)

1. 插入操作(鏈地址法)

template <typename K, typename V>
void HashMap<K,V>::put(K key, V value) {size_t index = hashFunction(key);HashNode<K,V>* node = buckets[index];while (node) { // 檢查鍵是否已存在if (node->key == key) {node->value = value;return;}node = node->next;}// 頭插法添加新節點HashNode<K,V>* newNode = new HashNode<K,V>(key, value);newNode->next = buckets[index];buckets[index] = newNode;size++;
}

2. 查找操作、

template <typename K, typename V>
V HashMap<K,V>::get(K key) {size_t index = hashFunction(key);HashNode<K,V>* node = buckets[index];while (node) {if (node->key == key) {return node->value;}node = node->next;}throw out_of_range("Key not found");
}

3. 刪除操作

template <typename K, typename V>
void HashMap<K,V>::remove(K key) {size_t index = hashFunction(key);HashNode<K,V>* node = buckets[index];HashNode<K,V>* prev = nullptr;while (node) {if (node->key == key) {if (prev) prev->next = node->next;else buckets[index] = node->next;delete node;size--;return;}prev = node;node = node->next;}
}

四、復雜度與優化

操作平均情況最壞情況
插入O(1)O(n)
刪除O(1)O(n)
查找O(1)O(n)

優化策略

  • 負載因子監控:當元素數/桶數超過閾值(如0.75),觸發擴容

  • 動態擴容:容量擴展為原來的2倍,并重新哈希所有元素

  • 良好的哈希函數選擇:減少沖突,提升性能

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

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

相關文章

LeetCode 第29題、30題

LeetCode 第29題&#xff1a;兩數相除 題目描述 給你兩個整數&#xff0c;被除數dividend和除數divisor。將兩數相除&#xff0c;要求不使用乘法、除法和取余運算。整數除法應該向零截斷&#xff0c;也就是截去其小數部分。例如&#xff0c;8.345將被截斷為8&#xff0c;-2.733…

26考研——樹與二叉樹_樹、森林(5)

408答疑 文章目錄 二、樹、森林樹的基本概念樹的定義和特性樹的定義樹的特性 基本術語樹的基本術語和概念祖先、子孫、雙親、孩子、兄弟和堂兄弟結點的層次、度、深度和高度樹的度和高度分支結點和葉結點有序樹和無序樹路徑和路徑長度 森林的基本術語和概念森林的定義森林與樹的…

【HarmonyOS Next之旅】DevEco Studio使用指南(六)

目錄 1 -> 在模塊中添加Ability 1.1 -> Stage模型添加UIAbility 1.1.1 -> 在模塊中添加UIAbility 1.1.2 -> 在模塊中添加Extension Ability 2 -> 創建服務卡片 2.1 -> 概述 2.2 -> 使用約束 2.3 -> 創建服務卡片 2.4 -> 創建動態/靜態卡片…

Langchain 多模態輸入和格式化輸出

多模態輸入 圖片處理&#xff08;最高頻&#xff09; 1.1 URL形式&#xff08;推薦大文件&#xff09; from langchain.schema import HumanMessage from langchain.chat_models import ChatOpenAIchat ChatOpenAI(model"gpt-4-vision-preview")message HumanMes…

Excel多級聯動下拉菜單的自動化設置(使用Python中的openpyxl模塊)

1 主要目的 在Excel中&#xff0c;經常會遇到需要制作多級聯動下拉菜單的情況&#xff0c;要求單元格內填寫的內容只能從指定的多個選項中進行選擇&#xff0c;并且需要設置多級目錄&#xff0c;其中下級目錄的選項內容要根據上級目錄的填寫內容確定&#xff0c;如下圖所示&am…

3.25-1 postman執行+弱網測試

1.導出json腳本 2.打包json文件 3.下載的文件 二 .導入腳本 選擇文件 點擊導入 導入的接口 三.多接口運行 &#xff08;1&#xff09;集合右鍵&#xff0c;點擊run &#xff0c;運行多個接口 2.編輯環境&#xff0c;集合&#xff0c;執行次數等 運行多個接口 四.運行多個接口…

Pear Admin Flask 開發問題

下載代碼請復制以下命令到終端執行 git clone https://gitee.com/pear-admin/pear-admin-flask 于是我下載git 完成安裝后&#xff1a; 安裝 Git 后出現的頁面是 “Git for Windows 的版本發布說明&#xff08;Release Notes&#xff09;”&#xff0c;通常會在安裝完成后自動彈…

12-scala樣例類(Case Classes)

例類&#xff08;Case classes&#xff09;和普通類差不多&#xff0c;只有幾點關鍵差別&#xff0c;接下來的介紹將會涵蓋這些差別。樣例類非常適合用于不可變的數據。 定義一個樣例類 一個最簡單的樣例類定義由關鍵字case class&#xff0c;類名&#xff0c;參數列表&#…

cmakelist中添加opencv

版本選擇 qt的msvc&#xff0c;版本2019 opencv版本 4.5.3 配置了環境變量 x64下的v14中的bin 配置頭文件 {"configurations": [{"name": "Win32","includePath": ["${workspaceFolder}","d:\\QT\\6.5.3\\msvc20…

【C語言】文件操作(詳解)

個人主頁 今天我們來講一下有關文件的相關操作&#xff0c;希望看完這篇文章對你有所幫助&#xff0c;大力感謝你對博主的支持&#xff01; 文章目錄 ?一、為什么使用文件&#x1f389;二、什么是文件2.1 程序文件2.2 數據文件2.3 文件名 &#x1f3a1;三、二進制文件和文本…

基于web的家政服務網站

內容摘要 由于互聯網的使用&#xff0c;人們在管理、應用、服務等領域使用數據更加簡潔、方便&#xff0c;大大提高了工作效率。互聯網正逐漸融入我們的生活&#xff0c;影響和改變我們的生活。 家政服務管理系統是典型的信息管理系統&#xff08;MIS&#xff09;。其開發主要…

【leetcode hot 100 739】每日溫度

解法一&#xff1a;暴力解法 class Solution {public int[] dailyTemperatures(int[] temperatures) {int ntemperatures.length; // 指向要找下一個更高溫度的地方int[] result new int[n];for(int left0;left<n;left){int rightleft1; // 指向正在找最高溫度的地方wh…

藍橋杯C++基礎算法-0-1背包(優化為一維)

這段代碼實現了0-1 背包問題的動態規劃解法&#xff0c;并且使用了滾動數組來優化空間復雜度。以下是代碼的詳細思路解析&#xff1a; 1. 問題背景 給定 n 個物品&#xff0c;每個物品有其體積 v[i] 和價值 w[i]&#xff0c;以及一個容量為 m 的背包。目標是選擇物品使得總價值…

算法 | 麻雀搜索算法原理,公式,改進算法綜述,應用場景及matlab完整代碼

一、麻雀搜索算法(SSA)原理 1. 算法基礎 麻雀搜索算法(Sparrow Search Algorithm, SSA)是2020年提出的一種群體智能優化算法,靈感來源于麻雀群體的覓食與反捕食行為。算法將麻雀分為三類角色:發現者(Producer):適應度最高,負責探索全局最優區域;加入者(Follower)…

SQL 版本歷史

SQL&#xff08;Structured Query Language&#xff09;是一種用于管理和操作關系數據庫的標準語言。SQL標準由多個組織制定和維護&#xff0c;主要包括以下幾個版本&#xff1a; SQL-86 (SQL-87): 這是SQL的第一個官方標準&#xff0c;由ANSI&#xff08;美國國家標準協會&…

CAT1模塊 EC800M HTTP 使用后續記錄

記錄一下 CAT1 模塊EC800 HTTP 使用后續遇到的問題 by 矜辰所致目錄 前言一、一些功能的完善1.1 新的交互指令添加1.2 連不上網絡處理 二、問題出現三、分析及解決3.1 定位問題3.2 問題分析與解決3.2.1 查看變量在內存中的位置 3.3 數據類型說明3.3.1 常用格式化輸出符號…

單純形法之大M法

1. 問題背景與標準化 在求解某些線性規劃問題時&#xff0c;往往難以直接找到初始的基本可行解。特別是當約束中存在等式或 “≥” 類型的不等式時&#xff0c;我們需要引入人工變量來構造一個初始可行解。 考慮如下標準形式問題&#xff08;假設為最大化問題&#xff09;&am…

Springboot集成Debezium監聽postgresql變更

1.創建springboot項目引入pom <dependencies><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-web</artifactId></dependency><dependency><groupId>io.debezium</groupI…

報錯 standard_init_linux.go:228: exec user process caused: exec format error

docker logs 容器名 報錯&#xff1a; standard_init_linux.go:228: exec user process caused: exec format error 或者 standard_init_linux.go:228: exec user process caused: input/output error 排查思路 1、檢查源鏡像的框架是否正確&#xff0c;是否amd64&#x…

Go 代理爬蟲

現在注冊&#xff0c;還送15美金注冊獎勵金 --- 亮數據-網絡IP代理及全網數據一站式服務商 使用代理服務器&#xff0c;通過 Colly、Goquery、Selenium 進行網絡爬蟲的基礎示例程序 本倉庫包含兩個分支&#xff1a; basic 分支包含供 Go Proxy Servers 這篇文章改動的基礎代碼…