91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

C語言實現的哈希表

發布時間:2020-06-12 09:34:02 來源:網絡 閱讀:1872 作者:Czyy1 欄目:編程語言

C語言實現的哈希表
哈希表可以簡單理解為多個鏈表的集合,將每個新的成員根據其哈希值進行分類,這樣可以加快鏈表的查找速度
參考:https://www.cnblogs.com/s-b-b/p/6208565.html

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

#define HASHSIZE 10

typedef unsigned int uint;
/*定義一個鏈表的節點*/
typedef struct Node{
    char key[17];
    char value[4];
    struct Node *next;
}Node;

/*定義一組鏈表*/
Node *node[HASHSIZE];

/*初始化:為鏈表頭開辟空間*/
int init(Node *node)
{
    node = (Node *)malloc(sizeof(Node));
    if(NULL == node)
        return 1;

    bzero(node, sizeof(Node));

    return 0;
}

/*計算哈希值*/
uint hash(const char *key){
    uint hash = 0;
    for(; *key; ++key)
    {
        hash = hash*33+*key;
    }
    return hash%HASHSIZE;
}

/*查找:根據哈希值得出index, 然后到對應的鏈表中查找*/
Node *lookup(const char *key)
{
    Node *np;
    uint index;
    index = hash(key);
    for(np = node[index];np;np = np->next){
        if(!strcmp(key, np->key))
            return np;
    }
    return NULL;
}

/*插入:先查找該值是否存在,然后計算哈希值,插入對應的鏈表*/
uint install(const char *key, const char *value)
{
    uint index;
    Node *np;

    if(!(np = lookup(key))){
        index = hash(key);
        np = (Node*)malloc(sizeof(Node));
        if(!np)
            return 1;
        strcpy(np->key, key);
        strcpy(np->value, value);

        np->next = node[index];
        node[index] = np;
    }
    return 0;
}

/*例:*/
int main(void)
{
    /*為哈希表插入一組數據*/
    char key[17] = "10.10.16.31";
    char value[4] = "001";
    install(key, value);

    char key1[17] = "10.10.16.32";
    char value1[4] = "002";
    install(key1, value1);

    char key2[17] = "10.10.16.33";
    char value2[4] = "003";
    install(key2, value2);

    char key3[17] = "10.10.16.34";
    char value3[4] = "004";
    install(key3, value3);

    char key4[17] = "10.10.16.41";
    char value4[4] = "005";
    install(key4, value4);

    Node *np;

    /*哈希表初始化:如果不為表頭賦值的話可以省略*/
    int i,j;
    for(i=0;i<HASHSIZE;i++){
        init(node[i]);
    }

    /*遍歷哈希表*/
    for(i=0; i<HASHSIZE; i++)
    {
        if(node[i]){
            printf("i:%d, key:%s, value:%s\n", i, node[i]->key, node[i]->value);

            np = node[i]->next;
            while(np){
                printf("key:%s, value:%s\n", np->key, np->value);
                np = np->next;
            }
        }
    }
    return 0;
}
向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

连山| 聊城市| 姚安县| 宁津县| 鸡西市| 呼玛县| 华池县| 吉安县| 五大连池市| 屏东市| 平远县| 裕民县| 太湖县| 古浪县| 原平市| 高要市| 道真| 七台河市| 年辖:市辖区| 郁南县| 毕节市| 温泉县| 西青区| 阳高县| 大同县| 基隆市| 华池县| 思南县| 临朐县| 江西省| 南漳县| 商河县| 睢宁县| 开阳县| 巩义市| 印江| 陆丰市| 正定县| 深圳市| 门源| 手游|