版權(quán)說(shuō)明:本文檔由用戶(hù)提供并上傳,收益歸屬內(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ì)文檔-傾情為你奉上專(zhuān)心-專(zhuān)注-專(zhuān)業(yè)專(zhuān)心-專(zhuān)注-專(zhuān)業(yè)精選優(yōu)質(zhì)文檔-傾情為你奉上專(zhuān)心-專(zhuān)注-專(zhuān)業(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)益歸上傳用戶(hù)所有。
- 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ì)用戶(hù)上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶(hù)上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶(hù)因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度智能家庭無(wú)線(xiàn)網(wǎng)絡(luò)接入服務(wù)合同3篇
- 二零二五年度生態(tài)保護(hù)區(qū)臨時(shí)設(shè)施搭建勞務(wù)分包合同范例4篇
- 科技創(chuàng)新推動(dòng)安全生產(chǎn)與環(huán)境保護(hù)的進(jìn)步
- 2025版旅行社與旅游保險(xiǎn)產(chǎn)品定制服務(wù)協(xié)議3篇
- 小學(xué)語(yǔ)文課堂中的師生互動(dòng)與心理溝通
- 智能化學(xué)校教學(xué)樓電氣安裝及優(yōu)化策略
- 建立高效且令人滿(mǎn)意的在線(xiàn)客戶(hù)服務(wù)團(tuán)隊(duì)
- 激發(fā)小學(xué)生學(xué)習(xí)熱情的夜空之旅天文科普教育活動(dòng)實(shí)施報(bào)告
- 二零二五版美團(tuán)商家糾紛處理及投訴解決協(xié)議4篇
- 2025年度建設(shè)項(xiàng)目環(huán)境影響評(píng)價(jià)與環(huán)保驗(yàn)收咨詢(xún)合同3篇
- 2025春夏運(yùn)動(dòng)戶(hù)外行業(yè)趨勢(shì)白皮書(shū)
- 《法制宣傳之盜竊罪》課件
- 通信工程單位勞動(dòng)合同
- 高低壓配電柜產(chǎn)品營(yíng)銷(xiāo)計(jì)劃書(shū)
- 租賃車(chē)輛退車(chē)協(xié)議
- 醫(yī)療護(hù)理技術(shù)操作規(guī)程規(guī)定
- 盤(pán)式制動(dòng)器中英文對(duì)照外文翻譯文獻(xiàn)
- 社會(huì)系統(tǒng)研究方法的重要原則
- 重癥醫(yī)學(xué)科健康宣教手冊(cè)
- 2022版《義務(wù)教育英語(yǔ)課程標(biāo)準(zhǔn)》解讀培訓(xùn)課件
- 五個(gè)帶頭方面談心談話(huà)范文三篇
評(píng)論
0/150
提交評(píng)論