C語言哈希表詳解

一、什麼是哈希表

哈希表是一種根據關鍵碼值(Key Value)直接進行訪問的數據結構。通俗的說,哈希表就是把一個關鍵碼值(Key Value)通過哈希函數轉換為一個索引,該索引指向在表中對應的記錄。哈希函數可以將任意長度的輸入映射為較小的固定長度的輸出。一般情況下,哈希表的查詢和插入操作的時間複雜度為 O(1),在某些特殊情況下,時間複雜度為 O(n)。

二、哈希表的實現

哈希表的實現主要包括哈希函數和哈希衝突處理兩部分。

1. 哈希函數

哈希函數是將關鍵碼值映射到哈希表中的位置的函數。

int hash_func(char *key)
{
    unsigned long hash = 5381;
    int c;
    while ((c = *key++))
        hash = ((hash << 5) + hash) + c; /* hash * 33 + c */
    return hash % HASH_SIZE;
}

hash_func() 函數採用了比較常用的「乘法散列法」,可以將字元串轉換為哈希表中的位置。

2. 哈希衝突處理

哈希衝突指的是兩個關鍵字經過哈希函數映射到了同一個位置的情況。

常見的哈希衝突處理方法有「鏈式解決法」和「開放定址法」。

鏈式解決法

鏈式解決法通過鏈表將哈希表中相同位置的多個元素串連在一起。

typedef struct NODE
{
    char *key;
    char *val;
    struct NODE *next;
} NODE;

NODE *hash_table[HASH_SIZE];

void put(char *key, char *val)
{
    int pos = hash_func(key);
    NODE *head = hash_table[pos];
    NODE *p = head;

    while (p)
    {
        if (strcmp(p->key, key) == 0)
        {
            p->val = val;
            return;
        }
        p = p->next;
    }

    NODE *new_node = (NODE*)malloc(sizeof(NODE));
    new_node->key = key;
    new_node->val = val;
    new_node->next = NULL;

    if (head == NULL)
        hash_table[pos] = new_node;
    else
    {
        p = head;
        while (p->next)
            p = p->next;
        p->next = new_node;
    }
}

char *get(char *key)
{
    int pos = hash_func(key);
    NODE *p = hash_table[pos];
    while (p)
    {
        if (strcmp(p->key, key) == 0)
            return p->val;
        p = p->next;
    }
    return NULL;
}

開放定址法

開放定址法是指當哈希衝突發生時,通過向前/後尋找空閑位置來解決衝突的方法。

char *hash_table[HASH_SIZE];

void put(char *key, char *val)
{
    int pos = hash_func(key);
    
    while (hash_table[pos] != NULL && strcmp(hash_table[pos], key) != 0)
    {
        pos = (pos + 1) % HASH_SIZE;
    }

    hash_table[pos] = val;
}

char *get(char *key)
{
    int pos = hash_func(key);
    
    while (hash_table[pos] != NULL && strcmp(hash_table[pos], key) != 0)
    {
        pos = (pos + 1) % HASH_SIZE;
    }

    return hash_table[pos];
}

三、哈希表的應用

哈希表廣泛應用於數據存儲、索引,如:資料庫中的索引、編譯器中的符號表、DNS解析中的緩存等。

四、總結

哈希表是一種基於哈希函數實現的數據結構,主要包括哈希函數和哈希衝突處理兩部分,通過鏈式解決法和開放定址法來處理哈希衝突。哈希表具有查詢和插入操作的時間複雜度為 O(1) 的優點,廣泛應用於數據存儲、索引等方面。

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

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

相關推薦

  • AES加密解密演算法的C語言實現

    AES(Advanced Encryption Standard)是一種對稱加密演算法,可用於對數據進行加密和解密。在本篇文章中,我們將介紹C語言中如何實現AES演算法,並對實現過程進…

    編程 2025-04-29
  • 學習Python對學習C語言有幫助嗎?

    Python和C語言是兩種非常受歡迎的編程語言,在程序開發中都扮演著非常重要的角色。那麼,學習Python對學習C語言有幫助嗎?答案是肯定的。在本文中,我們將從多個角度探討Pyth…

    編程 2025-04-29
  • Python被稱為膠水語言

    Python作為一種跨平台的解釋性高級語言,最大的特點是被稱為”膠水語言”。 一、簡單易學 Python的語法簡單易學,更加人性化,這使得它成為了初學者的入…

    編程 2025-04-29
  • OpenJudge答案1.6的C語言實現

    本文將從多個方面詳細闡述OpenJudge答案1.6在C語言中的實現方法,幫助初學者更好地學習和理解。 一、需求概述 OpenJudge答案1.6的要求是,輸入兩個整數a和b,輸出…

    編程 2025-04-29
  • Python按位運算符和C語言

    本文將從多個方面詳細闡述Python按位運算符和C語言的相關內容,並給出相應的代碼示例。 一、概述 Python是一種動態的、面向對象的編程語言,其按位運算符是用於按位操作的運算符…

    編程 2025-04-29
  • Python語言由荷蘭人為中心的全能編程開發工程師

    Python語言是一種高級語言,很多編程開發工程師都喜歡使用Python語言進行開發。Python語言的創始人是荷蘭人Guido van Rossum,他在1989年聖誕節期間開始…

    編程 2025-04-28
  • Python語言設計基礎第2版PDF

    Python語言設計基礎第2版PDF是一本介紹Python編程語言的經典教材。本篇文章將從多個方面對該教材進行詳細的闡述和介紹。 一、基礎知識 本教材中介紹了Python編程語言的…

    編程 2025-04-28
  • Python語言實現人名最多數統計

    本文將從幾個方面詳細介紹Python語言實現人名最多數統計的方法和應用。 一、Python實現人名最多數統計的基礎 1、首先,我們需要了解Python語言的一些基礎知識,如列表、字…

    編程 2025-04-28
  • Python作為中心語言,在編程中取代C語言的優勢和挑戰

    Python一直以其簡單易懂的語法和高效的編碼環境而著名。然而,它最近的發展趨勢表明Python的使用範圍已經從腳本語言擴展到了從Web應用到機器學習等廣泛的開發領域。與此同時,C…

    編程 2025-04-28
  • Python基礎語言

    Python作為一種高級編程語言擁有簡潔優雅的語法。在本文中,我們將從多個方面探究Python基礎語言的特點以及使用技巧。 一、數據類型 Python基礎數據類型包括整數、浮點數、…

    編程 2025-04-28

發表回復

登錄後才能評論