




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上精選優(yōu)質(zhì)文檔-傾情為你奉上專心-專注-專業(yè)專心-專注-專業(yè)精選優(yōu)質(zhì)文檔-傾情為你奉上專心-專注-專業(yè)哈希表算法hash表問(wèn)題描述:針對(duì)某個(gè)集體(比如你所在的班級(jí))中的“人名”設(shè)計(jì)一個(gè)哈希表,使得平均查找長(zhǎng)度不超過(guò)R,完成相應(yīng)的建表和查表程序?;疽螅杭僭O(shè)人名為中國(guó)人姓名的漢語(yǔ)拼音形式。待填入哈希表的人名共有30個(gè),取平均查找長(zhǎng)度的上限為2。哈希函數(shù)用除留余數(shù)法構(gòu)造,用偽隨機(jī)探測(cè)再散列發(fā)處理沖突。#include #include #include /#include #define HASH_LEN 50 /哈希表的長(zhǎng)度 #define M 47 #define N
2、AME_NO 30 /人名的個(gè)數(shù) typedef struct NAME char *py; /名字的拼音 int k; /拼音所對(duì)應(yīng)的整數(shù) NAME; NAME NameListHASH_LEN; typedef struct hterm /哈希表 char *py; /名字的拼音 int k; /拼音所對(duì)應(yīng)的整數(shù) int si; /查找長(zhǎng)度 HASH; HASH HashListHASH_LEN; /*-姓名(結(jié)構(gòu)體數(shù)組)初始化-*/ void InitNameList() NameList0.py=zhanghongshuai;NameList1.py=xurensong;NameLis
3、t2.py=huangxiangyu;NameList3.py=luoqi;NameList4.py=zhangsan;NameList5.py=lisi;NameList6.py=wangwu;NameList7.py=renwei;NameList8.py=zhangchu;NameList9.py=wangmengyuan;NameList10.py=libaohua;NameList11.py=zhaoyanlong;NameList12.py=jwangyuxin;NameList13.py=duyanmo;NameList14.py=wangmingyang;NameList15.
4、py=lijiawei;NameList16.py=hesiyu;NameList17.py=zhanghailong;NameList18.py=lixinyu;NameList19.py=songdiyao;NameList20.py=zhaomingzhi;NameList21.py=zhangchenglong;NameList22.py=sunjie;NameList23.py=zhangdongmei;NameList24.py=antianyu;NameList25.py=zhulaiao;NameList26.py=wangyuting;NameList27.py=wangxi
5、liang;NameList28.py=zhangdeshuai;NameList29.py=xumingming; char *f; int r,s0; for (int i=0;iNAME_NO;i+)/ 求出各個(gè)姓名的拼音所對(duì)應(yīng)的整數(shù) s0=0; f=NameListi.py; for (r=0;*(f+r) != 0;r+) /方法:將字符串的各個(gè)字符所對(duì)應(yīng)的ASCII碼相加,所得的整數(shù)做為哈希表的關(guān)鍵字 s0=*(f+r)+s0; NameListi.k=s0; /*-建立哈希表-*/ void CreateHashList() for (int i=0; iHASH_LEN;i+)
6、/哈希表的初始化 HashListi.py=; HashListi.k=0; HashListi.si=0; for (int i=0; i=NAME_NO;) int sum=0; int adr=(NameListi.k) % M; /哈希函數(shù) int d=adr; if(HashListadr.si=0) /如果不沖突 HashListadr.k=NameListi.k; HashListadr.py=NameListi.py; HashListadr.si=1; else /沖突 do d=(d+(NameListi.k)%10+1)%M; /偽散列 sum=sum+1; /查找次數(shù)加
7、1 while (HashListd.k!=0); HashListd.k=NameListi.k; HashListd.py=NameListi.py; HashListd.si=sum+1; i+; /*-查找-*/ void FindList() printf(nn請(qǐng)輸入姓名的拼音: ); /輸入姓名 char name20=0; scanf(%s,name); int s0=0; for (int r=0;r20;r+) /求出姓名的拼音所對(duì)應(yīng)的整數(shù)(關(guān)鍵字) s0+=namer; int sum=1; int adr=s0 % M; /使用哈希函數(shù) int d=adr; if(Has
8、hListadr.k=s0) /分3種情況進(jìn)行判斷 printf(n姓名:%s 關(guān)鍵字:%d 查找長(zhǎng)度為: 1,HashListd.py,s0); else if (HashListadr.k=0) printf(無(wú)該記錄!); else int g=0; do d=(d+s0%10+1)%M; /偽散列 sum=sum+1; if (HashListd.k=0) printf(無(wú)記錄! ); g=1; if (HashListd.k=s0) printf(n姓名:%s 關(guān)鍵字:%d 查找長(zhǎng)度為:%d,HashListd.py,s0,sum); g=1; while(g=0); /*-顯示哈希
9、表-*/ void Display() printf(nn地址t關(guān)鍵字tt搜索長(zhǎng)度tH(key)tt拼音 n); /顯示的格式 for(int i=0; i15; i+) printf(%d ,i); printf(t%d ,HashListi.k); printf(tt%d ,HashListi.si); printf(tt%d ,(HashListi.k)%M); printf(t %s ,HashListi.py); printf(n); / printf(按任意鍵繼續(xù)顯示.n); /由于數(shù)據(jù)比較多,所以分屏顯示(以便在Win9xDOS下能看到所有的數(shù)據(jù)) / getch(); for(
10、 int i=15; i30; i+) printf(%d ,i); printf(t%d ,HashListi.k); printf(tt%d ,HashListi.si); printf(tt%d ,(HashListi.k)%M); printf(t %s ,HashListi.py); printf(n); / printf(按任意鍵繼續(xù)顯示.n); / getch(); for( int i=30; i40; i+) printf(%d ,i); printf(t%d ,HashListi.k); printf(tt%d ,HashListi.si); printf(tt%d ,(H
11、ashListi.k)%M); printf(t %s ,HashListi.py); printf(n); /printf(按任意鍵繼續(xù)顯示.n); /getch(); for( int i=40; i50; i+) printf(%d ,i); printf(t%d ,HashListi.k); printf(tt%d ,HashListi.si); printf(tt%d ,(HashListi.k)%M); printf(t %s ,HashListi.py); printf(n); float average=0; for (int i=0;iHASH_LEN;i+) average
12、+=HashListi.si; average/=NAME_NO; printf(nn平均查找長(zhǎng)度:ASL(%d)=%f nn,NAME_NO,average); /*-主函數(shù)-*/ main() /* :SetConsoleTitle(哈希表操作); /Windows API函數(shù),設(shè)置控制臺(tái)窗口的標(biāo)題 HANDLE hCon = :GetStdHandle(STD_OUTPUT_HANDLE); /獲得標(biāo)準(zhǔn)輸出設(shè)備的句柄 :SetConsoleTextAttribute(hCon, 10|0); /設(shè)置文本顏色 */ printf(n-哈希表的建立和查找-); InitNameList(); CreateHashList (); while(1) printf(nn); printf( 1. 顯示哈
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 有線廣播信號(hào)傳輸技術(shù)考核試卷
- 永久征地合同范本
- 課程創(chuàng)新與改革方案計(jì)劃
- 科技在提升城市河道水質(zhì)中的應(yīng)用案例分析
- 生物科普講解活動(dòng)安排計(jì)劃
- 知識(shí)產(chǎn)權(quán)行業(yè)保安總結(jié)與展望計(jì)劃
- 2025年01月政協(xié)太原市小店區(qū)委員會(huì)公開(kāi)招聘勞務(wù)派遣制人員1人(山西)筆試歷年典型考題(歷年真題考點(diǎn))解題思路附帶答案詳解-1
- 主題美術(shù)作品展策劃計(jì)劃
- 科技與醫(yī)療融合的銀行對(duì)公業(yè)務(wù)探索
- 下學(xué)期開(kāi)學(xué)季家長(zhǎng)會(huì)主題課件+
- 《綠色建筑設(shè)計(jì)原理》課件
- 光伏電站小EPC規(guī)定合同范本
- 2024年01月江蘇2024年昆山鹿城村鎮(zhèn)銀行第三期校園招考筆試歷年參考題庫(kù)附帶答案詳解
- 《直播銷售》課件-項(xiàng)目一 認(rèn)識(shí)直播與直播銷售
- 中華人民共和國(guó)學(xué)前教育法-知識(shí)培訓(xùn)
- 2023年新高考(新課標(biāo))全國(guó)2卷數(shù)學(xué)試題真題(含答案解析)
- 事業(yè)單位工作人員獎(jiǎng)勵(lì)審批表
- 人教版六年級(jí)美術(shù)下冊(cè)全冊(cè)課件【完整版】
- GB/T 9788-1988熱軋不等邊角鋼尺寸、外形、重量及允許偏差
- 教科版三年級(jí)下冊(cè)科學(xué)全冊(cè)完整課件
- 學(xué)生流失率考核辦法(試行)
評(píng)論
0/150
提交評(píng)論