亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? bo9-7.cpp

?? 清華大學(xué)《數(shù)據(jù)結(jié)構(gòu)》教材第二版對(duì)應(yīng)的C++教學(xué)程序
?? CPP
字號(hào):
 // bo9-7.cpp 哈希函數(shù)的基本操作
 Status InitHashTable(HashTable &H)
 { // 操作結(jié)果: 構(gòu)造一個(gè)空的哈希表
   int i;
   H.count=0; // 當(dāng)前元素個(gè)數(shù)為0
   H.sizeindex=0; // 初始存儲(chǔ)容量為hashsize[0]
   m=hashsize[0];
   H.elem=(ElemType*)malloc(m*sizeof(ElemType));
   if(!H.elem)
     exit(OVERFLOW); // 存儲(chǔ)分配失敗
   for(i=0;i<m;i++)
     H.elem[i].key=NULLKEY; // 未填記錄的標(biāo)志
   return OK;
 }

 void DestroyHashTable(HashTable &H)
 { // 初始條件: 哈希表H存在。操作結(jié)果: 銷毀哈希表H
   free(H.elem);
   H.elem=NULL;
   H.count=0;
   H.sizeindex=0;
 }

 unsigned Hash(KeyType K)
 { // 一個(gè)簡單的哈希函數(shù)(m為表長,全局變量)
   return K%m;
 }

 void collision(int &p,int d) // 線性探測(cè)再散列
 { // 開放定址法處理沖突
   p=(p+d)%m;
 }

 Status SearchHash(HashTable H,KeyType K,int &p,int &c)
 { // 在開放定址哈希表H中查找關(guān)鍵碼為K的元素,若查找成功,以p指示待查數(shù)據(jù)
   // 元素在表中位置,并返回SUCCESS;否則,以p指示插入位置,并返回UNSUCCESS
   // c用以計(jì)沖突次數(shù),其初值置零,供建表插入時(shí)參考。算法9.17
   p=Hash(K); // 求得哈希地址
   while(H.elem[p].key!=NULLKEY&&!EQ(K,H.elem[p].key))
   { // 該位置中填有記錄.并且關(guān)鍵字不相等
     c++;
     if(c<m)
       collision(p,c); // 求得下一探查地址p
     else
       break;
   }
   if EQ(K,H.elem[p].key)
     return SUCCESS; // 查找成功,p返回待查數(shù)據(jù)元素位置
   else
     return UNSUCCESS; // 查找不成功(H.elem[p].key==NULLKEY),p返回的是插入位置
 }

 Status InsertHash(HashTable &,ElemType); // 對(duì)函數(shù)的聲明
 void RecreateHashTable(HashTable &H) // 重建哈希表
 { // 重建哈希表
   int i,count=H.count;
   ElemType *p,*elem=(ElemType*)malloc(count*sizeof(ElemType));
   p=elem;
   printf("重建哈希表\n");
   for(i=0;i<m;i++) // 保存原有的數(shù)據(jù)到elem中
     if((H.elem+i)->key!=NULLKEY) // 該單元有數(shù)據(jù)
       *p++=*(H.elem+i);
   H.count=0;
   H.sizeindex++; // 增大存儲(chǔ)容量
   m=hashsize[H.sizeindex];
   p=(ElemType*)realloc(H.elem,m*sizeof(ElemType));
   if(!p)
     exit(OVERFLOW); // 存儲(chǔ)分配失敗
   H.elem=p;
   for(i=0;i<m;i++)
     H.elem[i].key=NULLKEY; // 未填記錄的標(biāo)志(初始化)
   for(p=elem;p<elem+count;p++) // 將原有的數(shù)據(jù)按照新的表長插入到重建的哈希表中
     InsertHash(H,*p);
 }

 Status InsertHash(HashTable &H,ElemType e)
 { // 查找不成功時(shí)插入數(shù)據(jù)元素e到開放定址哈希表H中,并返回OK;
   // 若沖突次數(shù)過大,則重建哈希表,算法9.18
   int c,p;
   c=0;
   if(SearchHash(H,e.key,p,c)) // 表中已有與e有相同關(guān)鍵字的元素
     return DUPLICATE;
   else if(c<hashsize[H.sizeindex]/2) // 沖突次數(shù)c未達(dá)到上限,(c的閥值可調(diào))
   { // 插入e
     H.elem[p]=e;
     ++H.count;
     return OK;
   }
   else
     RecreateHashTable(H); // 重建哈希表
   return ERROR;
 }

 void TraverseHash(HashTable H,void(*Vi)(int,ElemType))
 { // 按哈希地址的順序遍歷哈希表
   printf("哈希地址0~%d\n",m-1);
   for(int i=0;i<m;i++)
     if(H.elem[i].key!=NULLKEY) // 有數(shù)據(jù)
       Vi(i,H.elem[i]);
 }

 Status Find(HashTable H,KeyType K,int &p)
 { // 在開放定址哈希表H中查找關(guān)鍵碼為K的元素,若查找成功,以p指示待查數(shù)據(jù)
   // 元素在表中位置,并返回SUCCESS;否則,返回UNSUCCESS
   int c=0;
   p=Hash(K); // 求得哈希地址
   while(H.elem[p].key!=NULLKEY&&!EQ(K,H.elem[p].key))
   { // 該位置中填有記錄.并且關(guān)鍵字不相等
     c++;
     if(c<m)
       collision(p,c); // 求得下一探查地址p
     else
     return UNSUCCESS; // 查找不成功(H.elem[p].key==NULLKEY)
   }
   if EQ(K,H.elem[p].key)
     return SUCCESS; // 查找成功,p返回待查數(shù)據(jù)元素位置
   else
     return UNSUCCESS; // 查找不成功(H.elem[p].key==NULLKEY)
 }

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲午夜精品网| 激情综合网av| 中文在线免费一区三区高中清不卡| 色婷婷久久久久swag精品| 激情综合一区二区三区| 一区二区三区在线免费| 久久蜜桃av一区二区天堂 | 夜色激情一区二区| 久久精品在这里| 日韩精品在线一区二区| 在线观看www91| 成人动漫一区二区| 国产一区二区在线观看免费| 丝袜美腿亚洲综合| 一区二区三区国产精华| 亚洲欧洲日韩女同| 国产视频一区二区在线观看| 日韩欧美123| 欧美年轻男男videosbes| 色综合久久中文字幕综合网 | 久久99久久精品欧美| 午夜不卡av在线| 亚洲狠狠丁香婷婷综合久久久| 国产欧美一二三区| 国产调教视频一区| 久久久欧美精品sm网站| 精品久久久久久最新网址| 91精品欧美综合在线观看最新| 欧洲国内综合视频| 色老汉一区二区三区| 91视频精品在这里| 99久久免费精品高清特色大片| 国产激情一区二区三区四区| 精品一区二区三区在线播放视频| 日韩高清一级片| 亚洲福利一二三区| 午夜精品视频在线观看| 亚洲成人动漫精品| 亚洲mv在线观看| 偷拍自拍另类欧美| 美日韩一区二区| 免费久久99精品国产| 精品一二三四区| 久久精品国内一区二区三区| 黄色精品一二区| 国产在线播精品第三| 国产一区二区三区在线看麻豆| 国内精品免费**视频| 国产xxx精品视频大全| 成人激情黄色小说| 91麻豆国产香蕉久久精品| 91久久精品一区二区三区| 欧美四级电影在线观看| 91麻豆精品国产91久久久更新时间 | 裸体一区二区三区| 国产在线视视频有精品| 国产91在线看| 色综合天天做天天爱| 欧美日韩一区三区四区| 欧美一级欧美三级在线观看| 精品剧情v国产在线观看在线| 久久久久青草大香线综合精品| 中文字幕不卡三区| 亚洲精品少妇30p| 免费看日韩a级影片| 国产99精品视频| 在线观看日韩电影| 欧美mv和日韩mv的网站| 欧美激情一区在线| 亚洲成人综合网站| 国产一区美女在线| 91女神在线视频| 欧美年轻男男videosbes| 久久久久久久一区| 一区二区三区高清在线| 久久精品国产一区二区| 99久久精品国产麻豆演员表| 欧美高清视频在线高清观看mv色露露十八 | 9久草视频在线视频精品| 欧美色精品天天在线观看视频| 欧美第一区第二区| 亚洲天堂成人在线观看| 麻豆一区二区三| 91蜜桃婷婷狠狠久久综合9色| 欧美妇女性影城| 中文字幕一区在线| 麻豆精品一二三| 在线视频一区二区免费| 国产日韩欧美精品在线| 一区二区在线观看av| 日本不卡高清视频| 一本到不卡精品视频在线观看| 欧美电影免费提供在线观看| 成人欧美一区二区三区小说| 久久精品国产亚洲一区二区三区| 色婷婷综合久久久中文字幕| 国产亚洲综合av| 日本欧美加勒比视频| 91浏览器在线视频| 国产日产欧美一区二区视频| 亚洲精品成a人| 国产不卡免费视频| 欧美一级淫片007| 亚洲免费大片在线观看| 国产成人午夜精品5599| 日韩欧美一区在线观看| 亚洲一区二区三区四区在线 | 欧美日韩三级视频| 久久伊人中文字幕| 日产精品久久久久久久性色| 91麻豆高清视频| 国产精品美女视频| 国产盗摄一区二区| 久久天天做天天爱综合色| 亚洲高清不卡在线| 91香蕉视频mp4| 欧美国产综合色视频| 国模一区二区三区白浆| 91麻豆精品国产自产在线| 亚洲成人自拍网| 欧美性生活久久| 亚洲精品ww久久久久久p站| 99久久综合狠狠综合久久| 久久精品夜色噜噜亚洲aⅴ| 久久精品二区亚洲w码| 欧美日韩国产高清一区| 一区二区在线看| 在线观看三级视频欧美| 亚洲一区二区三区中文字幕在线| 91丨九色丨尤物| 亚洲人成影院在线观看| 99久久777色| 日韩毛片一二三区| 99久久国产综合精品女不卡| 亚洲伦在线观看| 91在线精品秘密一区二区| 亚洲视频在线观看一区| 色999日韩国产欧美一区二区| 亚洲欧美日韩一区二区三区在线观看| 成人av在线电影| 国产精品欧美极品| 99久久99精品久久久久久| 亚洲精选免费视频| 欧美网站一区二区| 亚洲风情在线资源站| 欧美丰满美乳xxx高潮www| 日本不卡视频在线观看| 2020国产精品自拍| 丁香五精品蜜臀久久久久99网站| 国产精品第13页| 色菇凉天天综合网| 婷婷国产在线综合| 欧美mv日韩mv国产网站app| 国产激情精品久久久第一区二区| 久久久久久一二三区| 99久久伊人网影院| 午夜影视日本亚洲欧洲精品| 欧美一区二区视频在线观看2020 | 日本色综合中文字幕| 2024国产精品| 99久久精品免费看国产| 亚洲伊人伊色伊影伊综合网| 欧美老女人第四色| 国产一区91精品张津瑜| 精品国产露脸精彩对白| 不卡的电影网站| 亚洲高清视频的网址| 精品美女一区二区| 国产精品一区二区视频| 亚洲欧洲国产日本综合| 欧美精品成人一区二区三区四区| 精品中文字幕一区二区小辣椒| 国产精品久久久久影院| 91.com在线观看| 国产91在线观看| 午夜精品视频在线观看| 精品电影一区二区三区| 不卡视频在线看| 日本欧美韩国一区三区| 国产精品久久久久aaaa樱花| 91精品久久久久久蜜臀| 成人精品视频一区二区三区尤物| 亚洲国产综合91精品麻豆 | 肉色丝袜一区二区| 亚洲国产精品99久久久久久久久| 欧美日韩激情一区二区三区| 懂色av一区二区夜夜嗨| 性做久久久久久久久| 日本一区二区不卡视频| 欧美一区日本一区韩国一区| av电影在线观看一区| 久久99精品国产麻豆婷婷洗澡| 一区二区三区不卡视频在线观看| 久久综合九色综合欧美就去吻| 欧美三级韩国三级日本三斤| 丁香另类激情小说| 看国产成人h片视频| 亚洲综合色区另类av| 中文字幕高清一区| 日韩精品专区在线影院观看|