数据结构—哈希表.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
* * Increment是求增量序列的函数,它依赖于解决冲突的方法 int Increment(int i) //用线性探查法求第i个增量di { return i; } 求在哈希表T[0..M-1]中第i次探查的哈希地址hi,0≤i≤M-1 int Hash(KeyType k,int i) { return (h(k)+Increment(i))%M; } 在哈希表T[0..M-1]中查找K,成功时返回1。失败有两种情况:找到一个开放址时返回0;表满未找到时返回-1 int HashSearch(HashType T[],KeyType K,int *pos) { int i=0; //记录探查次数 do{ *pos=Hash(K,i); //求探查地址hi if(T[*pos].key==K) return 1; if(T[*pos].key==NIL) return 0; //查找到空结点返回 }while(++iM); //最多做M次探查 return -1; } //表满且未找到时,查找失败 * * 将新结点newnode插入哈希表T[0..M-1]中 void Hashlnsert(HashType T[],HashType newnode) { int pos,sign; sign=HashSearch(T,newnode.key,pos); if(!sign) //找到一个开放的地址pos T[pos]=newnode; //插入新结点newnode,插入成功 else //插人失败 if(sign0) printf(重复的关键字!); else { printf(“表满错误,终止程序执行!”); exit(0);} } * * 根据A[0..n-1]中结点建立哈希表T[0..M-1] void CreateHashTable(HashType T[],HashType A[],int n) { if(nM){ //用开放定址法处理冲突时,装填因子α须不大于1 printf(装填因子α须不大于1); exit(0); } for(i=0;iM;i++) T[i].key=NIL; //将各关键字清空,使地址i为开放地址 for(i=0;in;i++) //依次将A[0..n-1]插入到哈希表T[0..m-1]中 Hashlnsert(T,A[i]); } * * 2.基于链地址法的哈希表的建立 #define M 997 typedef int KeyType; typedef struct chain{ KeyType key; struct chain *next; }ChainType; int h(KeyType K) { return K%M; } * * 在链地址表示的哈希表中某条链中查找关键字K,找到返回该记录地址;否则返回空值; ChainType *HashSearch(ChainType *Ti, KeyType K,ChainType **end) { ChainType *pre,*cur; pre=NULL; cur=Ti; while(cur!=NULL cur-key!=K){ //查找 pre=cur; cur=cur-next; } *end=pre; if(cur==NULL) return NULL; //查找不到时,返回空值 else return cur; //查找到时,返回该记录地址 } * * 在链地址的哈希表T中若找不到关键字为K的记录,则插入该记录 int HashInsert(ChainType *T[],KeyType K) { ChainType *pre,*cur; i=h(K); cur=HashSearch(T[i],K,pre); if(cur==NULL){ //未找到时,在链表尾插入该记录 cur=(ChainType *)malloc(sizeof(ChainType)); cur-key=K; cur-next=NULL; if(pre==NULL) //在该链插入第一条记录 T[i]

文档评论(0)

xingyuxiaxiang + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档