版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上精選優(yōu)質(zhì)文檔-傾情為你奉上專心-專注-專業(yè)專心-專注-專業(yè)精選優(yōu)質(zhì)文檔-傾情為你奉上專心-專注-專業(yè)哈希表算法hash表問題描述:針對某個(gè)集體(比如你所在的班級)中的“人名”設(shè)計(jì)一個(gè)哈希表,使得平均查找長度不超過R,完成相應(yīng)的建表和查表程序。基本要求:假設(shè)人名為中國人姓名的漢語拼音形式。待填入哈希表的人名共有30個(gè),取平均查找長度的上限為2。哈希函數(shù)用除留余數(shù)法構(gòu)造,用偽隨機(jī)探測再散列發(fā)處理沖突。#include #include #include /#include #define HASH_LEN 50 /哈希表的長度 #define M 47 #define N
2、AME_NO 30 /人名的個(gè)數(shù) typedef struct NAME char *py; /名字的拼音 int k; /拼音所對應(yīng)的整數(shù) NAME; NAME NameListHASH_LEN; typedef struct hterm /哈希表 char *py; /名字的拼音 int k; /拼音所對應(yīng)的整數(shù) int si; /查找長度 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è)姓名的拼音所對應(yīng)的整數(shù) s0=0; f=NameListi.py; for (r=0;*(f+r) != 0;r+) /方法:將字符串的各個(gè)字符所對應(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請輸入姓名的拼音: ); /輸入姓名 char name20=0; scanf(%s,name); int s0=0; for (int r=0;r20;r+) /求出姓名的拼音所對應(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 查找長度為: 1,HashListd.py,s0); else if (HashListadr.k=0) printf(無該記錄!); else int g=0; do d=(d+s0%10+1)%M; /偽散列 sum=sum+1; if (HashListd.k=0) printf(無記錄! ); g=1; if (HashListd.k=s0) printf(n姓名:%s 關(guān)鍵字:%d 查找長度為:%d,HashListd.py,s0,sum); g=1; while(g=0); /*-顯示哈希
9、表-*/ void Display() printf(nn地址t關(guān)鍵字tt搜索長度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平均查找長度: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. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度桉樹種植與林業(yè)資源可持續(xù)利用合作協(xié)議3篇
- 二零二五年度打樁工程環(huán)境影響評價(jià)合同4篇
- 2025年度國際培訓(xùn)項(xiàng)目擔(dān)保書模板及服務(wù)合同4篇
- 2025年度害蟲防治與環(huán)境保護(hù)責(zé)任合同樣本4篇
- 2025版小型飛機(jī)買賣合同:含飛行員招聘服務(wù)3篇
- 管道工程專項(xiàng)施工方案
- 二零二五年風(fēng)力發(fā)電機(jī)組安裝與運(yùn)維合同范本3篇
- 2025年度租賃房屋租賃合同(含文化氛圍營造)4篇
- 二零二四年度新型水磨石材料分包施工合同3篇
- 2025年度建筑幕墻工程承包合同范本4篇
- 2024年山東省泰安市高考物理一模試卷(含詳細(xì)答案解析)
- 2025春夏運(yùn)動(dòng)戶外行業(yè)趨勢白皮書
- 《法制宣傳之盜竊罪》課件
- 通信工程單位勞動(dòng)合同
- 2024年醫(yī)療器械經(jīng)營質(zhì)量管理規(guī)范培訓(xùn)課件
- 高低壓配電柜產(chǎn)品營銷計(jì)劃書
- 2024年4月自考02202傳感器與檢測技術(shù)試題
- 重癥醫(yī)學(xué)科健康宣教手冊
- 2022版《義務(wù)教育英語課程標(biāo)準(zhǔn)》解讀培訓(xùn)課件
- 五個(gè)帶頭方面談心談話范文三篇
- 互聯(lián)網(wǎng)的發(fā)展歷程
評論
0/150
提交評論