链地址处理哈希冲突方法
生活随笔
收集整理的這篇文章主要介紹了
链地址处理哈希冲突方法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
基本原理就是:將地址沖突的一些不同的值,掛在同一條鏈表上。
舉例代碼如下:
//哈希表 /* 鏈地址發處理哈希沖突 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 ;}總結
以上是生活随笔為你收集整理的链地址处理哈希冲突方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 实变函数一窥
- 下一篇: 学习opengl(起步)