數(shù)據(jù)結(jié)構(gòu)——查找算法比較.doc_第1頁(yè)
數(shù)據(jù)結(jié)構(gòu)——查找算法比較.doc_第2頁(yè)
數(shù)據(jù)結(jié)構(gòu)——查找算法比較.doc_第3頁(yè)
數(shù)據(jù)結(jié)構(gòu)——查找算法比較.doc_第4頁(yè)
免費(fèi)預(yù)覽已結(jié)束,剩余1頁(yè)可下載查看

下載本文檔

版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

廣 西 大 學(xué) 實(shí) 驗(yàn) 報(bào) 告 姓名_馬瑞良_學(xué)號(hào)_0807100333_計(jì)網(wǎng)_專業(yè)_083_班_2009_年_12_月_08_日實(shí)驗(yàn)內(nèi)容 查找算法比較 指導(dǎo)教師 一、 實(shí)驗(yàn)內(nèi)容對(duì)各種查找算法進(jìn)行比較二、實(shí)驗(yàn)要求(1)任意輸入5組有序數(shù)據(jù);(2)對(duì)順序查找、折半查找、分塊查找的查找次數(shù)進(jìn)行比較并輸出比較結(jié)果。三、所需主要儀器及現(xiàn)有套數(shù):微機(jī) 臺(tái)軟件: visual C+四、程序源碼:#include#includeusing namespace std;typedef int Key;typedef structKey key;Rec;typedef structint index;Key data;Index;templatevoid px(Telem a,int n)int min,i,j;Telem temp;for(i=0;in-1;i+) min=i;for(j=i+1;jn;j+)if(ajamin)min=j;temp=ai;ai=amin;amin=temp;/正向順序查找int srch0(Rec r,int n,Key k,int &m)cout順序查找n;m=0;int i(0);while(m+,(ri.key!=k)&(in)return(-1);else return(i);/逆向順序查找int srch1(Rec r,int n,Key k,int &m)m=0;int i(n);r-1.key=k;while(m+,ri.key!=k)i-;return(i);/折半查找int efsrch(Rec r,int n,Key k,int &m)m=0;cout二分查找n;int low,hig,mid;low=0;hig=n;while(m+,low=hig)mid=(low+hig)/2;if(k=rmid.key)return(mid);else if(krmid.key)hig=mid-1;else low=mid+1;return(-1);/分塊查找(二分查找)int idxsrch(Rec r,int n,Key k,int &g,int &h)cout分塊查找n;g=0;h=0;int i;int l=(int)sqrt(n);int m=(n+l-1)/l;cout分塊數(shù): lendl;Index *ind;ind=new Indexl;for(i=1;i=l;i+)indi.index=i*m-1;indi.data=ri*m-1.key;i=1;while(g+,il)if(indi.datak)i+;else break;int low,hig,mid;low=i*m-m;hig=i*m-1;while(h+,low=hig)mid=(low+hig)/2;if(k=rmid.key)return(mid);else if(krmid.key)hig=mid-1;else low=mid+1;return(-1);void main()int n;int *a;coutn; a=new intn;int i,j,k,l,m,sx0,sx1,sx2,sx3,sx4;cout請(qǐng)輸入數(shù)組元素:n;for(i=0;iai;px(a,n);Rec *r;r=new Recn;for(i=0;in;i+)ri.key=ai;for(i=0;in;i+)coutri.key ;coutendl;coutm;/順序查找i=srch0(r,n,m,sx0);j=srch1(r,n,m,sx1); if(i=-1)cout查找失敗!n;else cout查找成功!n;cout正向查出的位置: i+1endl反向查出的位置: j+1endl;cout查找次數(shù): 正向查找 sx0 次,反向查找 sx1 次,共 sx0+sx1 次nn;/折半查找k=efsrch(r,n,m,sx2);if(k=-1)cout查找失敗!n;else cout查找成功!n; cout位置: k+1endl; cout查找次數(shù): sx2 次nn;/分塊查找l=idxsrch(r,n,m,sx3,sx4);if(l=-1)cout查找失敗!n;else cout查找成功!n;cout位置: l+1endl;cout查找次數(shù): 調(diào)用索引表 s

溫馨提示

  • 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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論