數(shù)據(jù)結(jié)構(gòu)(Java語(yǔ)言描述)(第2版)習(xí)題答案 單元7 同步訓(xùn)練答案_第1頁(yè)
數(shù)據(jù)結(jié)構(gòu)(Java語(yǔ)言描述)(第2版)習(xí)題答案 單元7 同步訓(xùn)練答案_第2頁(yè)
數(shù)據(jù)結(jié)構(gòu)(Java語(yǔ)言描述)(第2版)習(xí)題答案 單元7 同步訓(xùn)練答案_第3頁(yè)
數(shù)據(jù)結(jié)構(gòu)(Java語(yǔ)言描述)(第2版)習(xí)題答案 單元7 同步訓(xùn)練答案_第4頁(yè)
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡(jiǎn)介

單元7一、選擇題12345BAADA678910BCACA1112131415BCCBC二、簡(jiǎn)答題1.答:不適合!雖然有序的單鏈表的結(jié)點(diǎn)是按從小到大(或從大到?。╉樞蚺帕?,但因其存儲(chǔ)結(jié)構(gòu)為單鏈表,查找結(jié)點(diǎn)時(shí)只能從頭指針開(kāi)始逐步搜索,故不能進(jìn)行折半查找。二分查找的速度在一般情況下是快些,但在特殊情況下未必快。例如所查數(shù)據(jù)位于首位時(shí),則線(xiàn)性查找快;而二分查找則慢得多。2.答:使用二分查找時(shí),線(xiàn)性表必須采用順序存儲(chǔ)結(jié)構(gòu),而且表中元素按關(guān)鍵字有序排列。3.查找元素54,需依次與30,63,42,54等元素比較;ASL=1/12(1+2×2+4×3+5×4=)=37/12≈3.084.按照序列得到的二叉排序樹(shù)如下所示:二叉排序樹(shù)中依次刪除57,82,71后的二叉排序樹(shù)如下所示:5.答:③6.平衡二叉排序樹(shù)如下所示:等概率下,查找成功的平均查找長(zhǎng)度:ASL=1/12(1+2×2+4×3+4×4+5)=38/12≈3.17三、算法設(shè)計(jì)題1.publicstaticBiTNode<T>searchNode(BiTNode<T>t,KeyTypekx){ while(t!=null){ if(t.data.key==kx){//查找成功 returnt; }elseif(kx<t.data.key){//關(guān)鍵字小于當(dāng)前子樹(shù)的根結(jié)點(diǎn)的關(guān)鍵字 t=t.lchild;//在左子樹(shù)查找 }else{ t=t.rchild;//在右子樹(shù)查找 } } returnnull; }2.publicclassChocolateDistribution{publicstaticvoidmain(String[]args){Scannerscanner=newScanner(System.in);intn=scanner.nextInt();//巧克力的塊數(shù)intk=scanner.nextInt();//小朋友的人數(shù)int[][]chocolates=newint[n][2];//存儲(chǔ)每塊巧克力的長(zhǎng)和寬for(inti=0;i<n;i++){chocolates[i][0]=scanner.nextInt();chocolates[i][1]=scanner.nextInt();}intleft=1;//二分查找的左邊界,最小邊長(zhǎng)為1intright=getMaxDimension(chocolates);//二分查找的右邊界,最大邊長(zhǎng)為巧克力長(zhǎng)或?qū)挼淖畲笾祑hile(left<right){intmid=(left+right+1)/2;//取中間值,這里向上取整,防止死循環(huán)intcount=0;//記錄當(dāng)前邊長(zhǎng)下能切出的巧克力總數(shù)for(inti=0;i<n;i++){count+=(chocolates[i][0]/mid)*(chocolates[i][1]/mid);//計(jì)算每塊巧克力能切出的邊長(zhǎng)為mid的正方形巧克力數(shù)量if(count>=k){break;//如果已經(jīng)滿(mǎn)足小朋友數(shù)量,無(wú)需繼續(xù)計(jì)算}}if(count>=k){left=mid;//如果當(dāng)前邊長(zhǎng)能滿(mǎn)足小朋友數(shù)量,嘗試更大的邊長(zhǎng),更新左邊界}else{right=mid-1;//如果當(dāng)前邊長(zhǎng)不能滿(mǎn)足小朋友數(shù)量,嘗試更小的邊長(zhǎng),更新右邊界}}System.out.println(left);//輸出最大的邊長(zhǎng)scanner.close();}publicstaticintgetMaxDimension(int[][]chocolates){intmax=0;for(inti=0;i<chocolates.length;i++){for(intj=0;j<2;j++){max=Math.max(max,chocolates[i][j]);//找到巧克力長(zhǎng)和寬中的最大值

溫馨提示

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

評(píng)論

0/150

提交評(píng)論