日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

链地址处理哈希冲突方法

發布時間:2025/3/15 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 链地址处理哈希冲突方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

基本原理就是:將地址沖突的一些不同的值,掛在同一條鏈表上。

舉例代碼如下:

//哈希表 /* 鏈地址發處理哈希沖突 2015年8月24日09:19:49 */#include<stdio.h> #include<malloc.h> #include<string.h>typedef struct node{char *name ;char *desc ;struct node *next ;}node ;static node * nodelist[100];//哈希表void inithashtab( ){int i = 0 ;for (i;i<100 ; i++ ){nodelist[i] = NULL ;}}unsigned int hash(char *name){int sum = 0 ;while (*name)sum+=*(name++);return sum%100 ; }node* lookup(char *s){//確保相同的name對應相同的descint i = hash(s);node *np = nodelist[i] ;for ( ; np ; np=np->next){if (!strcmp(np->name,s))return np;}return NULL;}char *get_str (char *s){int s_l = strlen(s) ;s_l++;char *t = (char *)malloc(sizeof(char)*s_l);strcpy(t,s);return t;}int install(char *name ,char *desc){int i = hash(name) ;node *np;if ((np=lookup(name))!=NULL){free(np->desc);np->desc =get_str(desc);}else{//插入新節點// printf("1");np = (node *)malloc(sizeof(node));np->name = get_str(name);np->desc = get_str(desc);np->next = nodelist[i] ;nodelist[i] = np ;}return 1;}char *get (char *name){int pos = hash(name );node *np = NULL ;np = lookup(name);if (!np){return NULL;}else{// printf("desc: %s\n",np->desc);return np->desc;}}int main (){inithashtab();// printf("%s",get_str("124"));install("name","desc") ;install("nbmd","aaaa");install("name","bbbb");char *s = get("name");printf("%s\n" , s);printf("%s",get("nbmd"));return 0 ;}

總結

以上是生活随笔為你收集整理的链地址处理哈希冲突方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。