第1章 緒論習(xí)題參考答案_第1頁
第1章 緒論習(xí)題參考答案_第2頁
第1章 緒論習(xí)題參考答案_第3頁
第1章 緒論習(xí)題參考答案_第4頁
全文預(yù)覽已結(jié)束

下載本文檔

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

文檔簡介

1、習(xí)題一參考答案一、概念題1. 試述下列各組概念: 數(shù)據(jù)、數(shù)據(jù)元素、數(shù)據(jù)項 數(shù)據(jù)結(jié)構(gòu)、數(shù)據(jù)的邏輯結(jié)構(gòu)、數(shù)據(jù)的存儲結(jié)構(gòu) 數(shù)據(jù)類型、數(shù)據(jù)操作 算法、算法的時間復(fù)雜度、算法的空間復(fù)雜度參考答案: 略2試述數(shù)據(jù)結(jié)構(gòu)研究的3個方面的內(nèi)容。參考答案: 數(shù)據(jù)結(jié)構(gòu)研究的3個方面分別是數(shù)據(jù)的邏輯結(jié)構(gòu)、數(shù)據(jù)的存儲結(jié)構(gòu)和數(shù)據(jù)的運算(操作)。3試述集合、線性結(jié)構(gòu)、樹型結(jié)構(gòu)和圖型結(jié)構(gòu)四種常用數(shù)據(jù)結(jié)構(gòu)的特性。參考答案: 集合結(jié)構(gòu):集合中數(shù)據(jù)元素之間除了“同屬于一個集合”的特性外,數(shù)據(jù)元素之間無其它關(guān)系,它們之間的關(guān)系是松散性的。 線性結(jié)構(gòu):線性結(jié)構(gòu)中數(shù)據(jù)元素之間存在“一對一”的關(guān)系。即若結(jié)構(gòu)非空,則它有且僅有一個開始結(jié)點和

2、終端結(jié)點,開始結(jié)點沒有前趨但有一個后繼,終端結(jié)點沒有后繼但有一個前趨,其余結(jié)點有且僅有一個前驅(qū)和一個后繼。 樹形結(jié)構(gòu):樹形結(jié)構(gòu)中數(shù)據(jù)元素之間存在“一對多”的關(guān)系。即若結(jié)構(gòu)非空,則它有一個稱為根的結(jié)點,此結(jié)點無前驅(qū)結(jié)點,其余結(jié)點有且僅有一個前驅(qū),所有結(jié)點都可以有多個后繼。 圖形結(jié)構(gòu):圖形結(jié)構(gòu)中數(shù)據(jù)元素之間存在“多對多”的關(guān)系。即若結(jié)構(gòu)非空,則在這種數(shù)據(jù)結(jié)構(gòu)中任何結(jié)點都可能有多個前驅(qū)和后繼。4設(shè)有數(shù)據(jù)的邏輯結(jié)構(gòu)的二元組定義形式為B=(D,R),其中D=a1,a2,an,R=<ai,ai+1>| i=1,2,,n-1,請畫出此邏輯結(jié)構(gòu)對應(yīng)的順序存儲結(jié)構(gòu)和鏈式存儲結(jié)構(gòu)的示意圖。參考答案:

3、順序存儲結(jié)構(gòu)示意圖如下: 鏈式存儲結(jié)構(gòu)示意圖如下:5設(shè)一個數(shù)據(jù)結(jié)構(gòu)的邏輯結(jié)構(gòu)如圖1.9所示,請寫出它的二元組定義形式。圖1.9 第5題的邏輯結(jié)構(gòu)圖參考答案: 它的二元組定義形式為B=(D,R),其中D=k1,k2,k3,k4,k5,k6,k7,k8,k9,R=<k1,k3>,<k1,k8>,<k2,k3><k2,k4>,<k2,k5>,<k3,k9>,<k4,k6>,<k4,k7>,<k5,k6>,<k8,k9>,<k9,k7> 。6設(shè)有函數(shù)f (n)=3n2-n

4、+4,請證明f (n)=O(n2)。證明:因為存在c=6,N=1,對所有的nN ,0 3n2-n+46×n2都是恒成立的,所以由書P16的定義可得f (n)=O(n2)。7請比較下列函數(shù)的增長率,并按增長率遞增的順序排列下列函數(shù):(1) 2100 (2) (3/2)n (3) (4/3)n (4) nn (5) n2/3 (6) n3/2 (7) n! (8)(9) n (10) log2n (11) 1/log2n (12)log2(log2n) (13)nlog2n (14) nlog2n參考答案: 按增長率遞增的排列順序是:1/log2n< 2100  

5、;<log2(log2n)<log2n<n1/2 <n2/3 <n <nlog2n <n3/2 <nlog2n<(4/3)n  < (3/2)n  < n! <nn8試確定下列程序段中有標記符號“*”的語句行的語句頻度(其中n為正整數(shù))。 i=1; k=0; while ( i<=n-1) k += 10 * i; /* i+; i=1; k=0;do k +=10 * i; /* i+; while(i<=n-

6、1); i = 1; k = 0;while (i<=n-1) i+ ; k+= 10 * i; /* k=0;for( i=1; i<=n; i+) for (j=1 ; j<=i; j+) k+; /* i=1; j=0;while (i+j<=n) if (i>j ) j+ ; /* else i+ ; x=n; y=0; / n 是不小于1的常數(shù)while (x>=(y+1)*(y+1) y+; /* x=91; y=100;while (y>0 ) if (x>100 ) x -= 10; y- -; /* else x+; a=1;

7、m=1; while(a<n) m+=a; a*=3; /* 參考答案: 指定語句行的語句頻度分別為:(1)n-1 (2) 當n1時語句頻yac 為1,當n>1時語句頻度為n-1(3) n-1(4) n(n+1)/2(5) n(6) 取整(7) 1100(8) log3n二、算法設(shè)計題1有一個包括100 個數(shù)據(jù)元素的數(shù)組,每個數(shù)據(jù)元素的值都是實數(shù),試編寫一個求最大數(shù)據(jù)元素的值及其下標的算法,并分析算法的時間復(fù)雜度。參考答案:void max(double a) double max = a0;/ 初始化最大值為數(shù)組中的第一個元素 int index = 0; / for (int

8、i = 0; i < a.length; i+) if (max < ai) max = ai;index = i; System.out.println("最大的實數(shù)為:" + max + "n其在數(shù)組中的下標為:" + index); 此算法的時間復(fù)雜度為O(n) ,其中n為數(shù)組的長度。2試編寫一個求一元多項式的值Pn(x0)的算法,并確定算法中每一條語句的執(zhí)行次數(shù)和整個算法的時間復(fù)雜度。輸入是ai(i=0,1,2,n-1)和x0,輸出為Pn(x0)。參考答案:0 double getPolynomialResult(double a, double x) /a是多項式中系數(shù)數(shù)組1 double result = 0;2 double powX = 1;/ 臨時變量,用于減少計算x冪的計算次數(shù)3 for (int i = 0; i < a.length; i+) 4result +=

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論