《大數據結構》課程習題集
《《大數據結構》課程習題集》由會員分享,可在線閱讀,更多相關《《大數據結構》課程習題集(25頁珍藏版)》請在裝配圖網上搜索。
1、word 《數據結構》課程習題集 第 1 頁 〔共 25 頁〕 一、. 選擇題 . 1. 算法的計算量的大小稱為計算的〔 〕。 A.效率 B. 復雜性 C. 現(xiàn)實性 D. 難度 .2. 算法的時間復雜度取決于〔 〕. A.問題的規(guī)模 B. 待處理數據的初態(tài) C. A和B D. 難確定 .3. 下面關于算法說法錯誤的答案是〔 〕 A.算法最終必須由計算機程序實現(xiàn) C. 算法的可行性是指指令不能有二義性 D. 以上幾個都是錯誤的 .4.從邏輯上可以把數據結構分為〔
2、〕兩大類。 A.動態(tài)結構、靜態(tài)結構 B.順序結構、鏈式結構 C.線性結構、非線性結構 D.初等結構、構造型結構 .5.以下數據結構中,哪一個是線性結構〔 〕? A.廣義表 B. 二叉樹 C. 稀疏矩陣 D. 串 .6.下述哪一條是順序存儲結構的優(yōu)點?〔 〕 A.存儲密度大 B.插入運算方便 C.刪除運算方便 D.可方便地用于各種邏輯結構的存儲表示 .7.下面關于線性表的表示中,錯誤的答案是哪一個?〔 〕 A.線性表采用順序存儲,必須占用一片連續(xù)的存儲單元。 B.線性表采用順序存儲,便于進展插入和刪除操作。 C
3、.線性表采用存儲,不必占用一片連續(xù)的存儲單元。 D.線性表采用存儲,便于插入和刪除操作。 .8.假如某線性表最常用的操作是存取任一指定序號的元素和在最后進展插入和刪除運算,如此利用〔 〕存儲方式最節(jié)省時間。 A.順序表 B.雙鏈表 C.帶頭結點的雙循環(huán)鏈表 D.單循環(huán)鏈表 .9.設一個鏈表最常用的操作是在末尾插入結點和刪除尾結點,如此選用( )最節(jié)省時間。 .10. 鏈表不具有的特點是〔 〕. A.插入、刪除不需要移動元素 B.可隨機訪問任一元素 C.不必事先估計存儲空間 D.所需空間與線性長度成正比 .11
4、. 設一個棧的輸入序列是 1,2,3,4,5,如此如下序列中,是棧的合法輸出序列的是〔 〕。 A. 5 1 2 3 4 B. 4 5 1 3 2 C. 4 3 1 2 5 D. 3 2 1 5 4 .12. 某堆棧的輸入序列為a, b,c ,d,下面的四個序列中,不可能是它的輸出序列的是〔 〕。 A. a,c,b,d B. b, c,d,a C. c, d,b, a D. d, c,a,b .13. 用方式存儲的隊列,在進展刪除運算時〔 〕。 A. 僅修改頭指針 B. 僅修改尾指針
5、 C. 頭、尾指針都要修改 D. 頭、尾指針可能都要修改 .14. 用不帶頭結點的單鏈表存儲隊列時,其隊頭指針指向隊頭結點,其隊尾指針指向隊尾結點,如此在進展刪除操作時( )。 A.僅修改隊頭指針 B. 僅修改隊尾指針 C. 隊頭、隊尾指針都要修改 D. 隊頭,隊尾指針都可能要修改 .15.下面關于串的的表示中,哪一個是不正確的?〔 〕 A.串是字符的有限序列 B.空串是由空格構成的串 C.模式匹配是串的一種重要運算 D.串既可以采用順序存儲,也可以采用鏈式存儲 .16. 串是一種特殊的線性表,其特殊性表現(xiàn)在 (
6、 ) A.可以順序存儲 B.數據元素是一個字符 C.可以存儲 D.數據元素可以是多個字符 .17.關于空串與空格串,下面說法正確的答案是( )。 A.空串與空格串是一樣的 B.空串與空格串長度是一樣的 C.空格串中存放的都是空格 D.空串中存放的都是NULL . 18.圖中有關路徑的定義是〔 〕。 A.由頂點和相鄰頂點序偶構成的邊所形成的序列 B.由不同頂點所形成的序列 C.由不同邊所形成的序列 D.上述定義都不是 .19.設無向圖的頂點個數
7、為n,如此該圖最多有〔 〕條邊。 A.n-1 B.n(n-1)/2 C. n(n+1)/2 D.0 E.n2 .20.一個n個頂點的連通無向圖,其邊的個數至少為〔 〕。 A.n-1 B.n C.n+1 D.nlogn; .21.某內排序方法的穩(wěn)定性是指( )。 A.該排序算法不允許有一樣的關鍵字記錄 B.該排序算法允許有一樣的關鍵字記錄 C.平均時間為0〔n log n〕的排序方法 D.以上都不對 .22.如果只想得到1000個元素組成的序列中第5個最小元素
8、之前的局部排序的序列,用〔 〕方法最快。 A.起泡排序 B.快速排列 C.Shell排序 D.堆排序 E.簡單項選擇擇排序 .23.排序趟數與序列的原始狀態(tài)有關的排序方法是( )排序法。 A.插入 B. 選擇 C. 冒泡 D. 都不是 .24.下面給出的四種排序方法中,排序過程中的比擬次數與排序方法無關的是。( ) A.選擇排序法 B. 插入排序法 C. 快速排序法 D. 都不是 .25.對序列{15,9,7,8,20,-1,4}進展排序,進展一趟后數據的排列變?yōu)閧4,9,-1,8,20,7,15};如此采用的是〔 〕
9、排序。 A. 選擇 B. 快速 C. 希爾 D. 冒泡 .26. 設樹T的度為4,其中度為1,2,3和4的結點個數分別為4,2,1,1 如此T中的葉子數為〔 〕 A.5 B.6 C.7 D.8 .27.一棵完全二叉樹上有1001個結點,其中葉子結點的個數是〔 〕 A. 250 B. 500 C.254 D.505 E.以上答案都不對 .28. 有關二叉樹如下說法正確的答案是〔 〕. A.二叉樹的度為2
10、 B.一棵二叉樹的度可以小于2 C.二叉樹中至少有一個結點的度為2 D.二叉樹中任何一個結點的度都為2 .29.二叉樹的第I層上最多含有結點數為〔 〕. A.2I B. 2I-1-1 C. 2I-1 D.2I -1 .30.對于有n 個結點的二叉樹, 其高度為〔 〕. A.nlog2n B.log2n C.?log2n?|+1 D.不確定 .31.對二
11、叉樹的結點從1開始進展連續(xù)編號,要求每個結點的編號大于其左、右孩子的編號,同一結點的左右孩子中,其左孩子的編號小于其右孩子的編號,可采用( )次序的遍歷實現(xiàn)編號。 A.先序 B. 中序 C. 后序 D. 從根開始按層次遍歷 .32. 對N個元素的表做順序查找時,假如查找每個元素的概率一樣,如此平均查找長度為( ) A.〔N+1〕/2 B. N/2 C. N D. [〔1+N〕*N ]/2 .33. 對線性表進展二分查找時,要求線性表必須〔 〕 A.以順序方式存儲 B.以順序方式存儲,
12、且數據元素有序 C.以方式存儲 D.以方式存儲,且數據元素有序 .34.當在一個有序的順序存儲表上查找一個數據時,即可用折半查找,也可用順序查找,但前者比后者的查找速度( ). A.必定快 B.不一定 C. 在大局部情況下要快 D. 取決于表遞增還是遞減 .35. 具有12個關鍵字的有序表,折半查找的平均查找長度〔 〕 . A. 3.1 B. 4 C. 2.5 D. 5 .36. 既希望較快的查找又便于線性表動態(tài)變化的查找方法是 ( ) A.順序查找 B. 折半查找 C. 索引順序查找 D. 哈希法查找 二
13、、填空題 .1. 對于長度為255的表,采用分塊查找,每塊的最優(yōu)長度為__________。 .2. 順序查找n個元素的順序表,假如查找成功,如此比擬關鍵字的次數最多為__ __次;當使用監(jiān)視哨時,假如查找失敗,如此比擬關鍵字的次數為__ __。 .3.在有序表A[1..12]中,采用二分查找算法查等于A[12]的元素,所比擬的元素下標依次為__________。 .4.. 在一棵二叉樹中,第5層上的結點數最多為個。 .5.、n(n>0)個結點構成的二叉樹,葉結點最多有個,最少有個。假如二叉樹有m個葉結點,如此度為2的結點有個。 .6.二叉樹中某一結點左子樹的深度減去右子樹的深
14、度稱為該結點的____。 .7. 假定一棵二叉樹的結點數為18,如此它的最小深度為,最大深度為; .8. 在一棵二叉樹中,度為零的結點的個數為n 0,度為2的結點的個數為 n 2,如此有n0=。 .9. 現(xiàn)有按中序遍歷二叉樹的結果為abc,問有____種不同形態(tài)的二叉樹可以得到這一遍歷結果,這些二叉樹分別是____。 .10.假如不考慮基數排序,如此在排序過程中,主要進展的兩種根本操作是關鍵字的______和記錄的_____。 .11.直接插入排序用監(jiān)視哨的作用是_______。 .12. 不受待排序初始序列的影響,時間復雜度為O(N2)的排序算法是_____,在排序算法的最后一趟
15、開始之前,所有元素都可能不在其最終位置上的排序算法是_____。 ______。 .14.具有10個頂點的無向圖,邊的總數最多為______。 .15.假如用n表示圖中頂點數目,如此有_______條邊的無向圖成為完全圖。 .16.空格串是指__ _,其長度等于__ __。 .17.設T和P是兩個給定的串,在T中尋找等于P的子串的過程稱為_ __,又稱P為__ __。 .18.串的兩種最根本的存儲方式是__ __、__ __;兩個串相等的充分必要條件是_ __。 .19. 鏈隊列的頭尾指針分別是f和r,如此將值x入隊的操作序列是_______。 .20.向棧中壓入元素的操作
16、是____。 .21.在具有n個單元的循環(huán)隊列中,隊滿時共有___個元素。 .22.用S表示入棧操作,X表示出棧操作,假如元素入棧的順序為1234,為了得到1342出棧順序,相應的S和X的操作串為_______。 .23. 單鏈表是____的存儲表示。 .24. 在雙鏈表中,每個結點有兩個指針域,一個指向____,另一個指向____。 .25.存儲的特點是利用________來表示數據元素之間的邏輯關系。 .26.順序存儲結構是通過________表示元素之間的關系的;鏈式存儲結構是通過________表示元素之間的關系的。 .27.線性表L=〔a1,a2,…,an〕用數組
17、表示,假定刪除表中任一元素的概率一樣,如此刪除一個元素平均需要移動元素的個數是________。 .28.根據線性表的鏈式存儲結構中每一個結點包含的指針個數,將線性鏈表分成________和_______;而又根據指針的連接方式,鏈表又可分成________和________。 .29.數據的物理結構包括的表示和的表示。 .30.抽象數據類型的定義僅取決于它的一組__ _,而與_ _無關,即不論其內部結構如何變化,只要它的_ _不變,都不影響其外部使用。 .31.數據結構中評價算法的兩個重要指標是 .32. 數據結構是研討數據的_和_ ,以與它們之間的相互關系,
18、并對與這種結構定義相應的,設計出相應的 _。
.三.程序填空題
.1. 單鏈表H為一個用帶頭結點的鏈表表示的線性表,如下算法是將其倒置。
請在下劃線處填上正確的語句。 P46
template
19、k;head–>link=p; }
first=head–>link; delete head;}
.2.在順序表中隨機存取的數據,很容易在順序表中實現(xiàn)按序號查找元素。代碼如下所示,請在下劃線處填上正確的語句。
template
20、return ____________ ; } .3.線性表的插入操作是指在線性表的第m–1個數據元素和第m個數據元素之間插入一個新的數據元素x,其結果是使長度為n的線性表(a1, a2 ,…, am–1, am,…, an)變成長度為n+1的線性表(a1, a2 ,…, am–1, x, am,…, an),并且數據元素am–1和am之間的邏輯關系發(fā)生了變化。 實現(xiàn)步驟如下:(1)合法性判斷:插入位置i是否合法?表是否已滿?(2)將第i至第n位的元素向后移動一個位置;(3)將要插入的元素寫到第i個數據元素的位置;(4)表長加1。 具體算法如下,請在下劃線處填上正確的語句。 t
21、emplate
22、4.-冒泡排序〔Bubble Sort〕的根本思想是:設數組a中存放了n個數據元素,循環(huán)進展n 趟如下的排序過程,請在下劃線處填上正確的語句。 void BubbleSort(DataType a[ ], int n) { int i, j, flag=1; DataType temp; for(i = 1; ____________ ; i++) { flag = 0; for(j = 0; ____________ ; j++) { if(____________ ) {
23、
flag = 1;
temp = a[j]; a[j] = a[j+1]; a[j+1] = temp;
}
}
}
}
.5.按值查找是指在線性表中查找與給定值x相等的數據元素,具體實現(xiàn)代碼如下,請在下劃線處填上正確的語句。
template
24、0 while(____________ ) i++; if (elem[i]= =x) return ++i; else return ____________ ; } .6.線性表的刪除操作是使長度為n的線性表(a1, a2,…, am–1, am,…,an)變?yōu)殚L度為n–1的線性表(a1, a2,…, am–1, am+1,,…,an),并且數據元素am–1、am和am+1之間的邏輯關系也會發(fā)生變化,需要把第m+1~n個元素〔共n–m個元素〕依次向前移動一個位置來反映這種變化。具體實現(xiàn)步驟如下:①判斷刪除位置i是否合法,合
25、法如此將該位置元素放入x中,否如此拋出異常;②將第i+1至第n位的元素向前移動一個位置;③表長減1。
具體算法如下,請在下劃線處填上正確的語句。
template 26、throw OutOfBounds( );
}
}
.7. 假設以數組a[m]存放循環(huán)隊列的元素,同時設變量rear 和length分別作為隊尾指針和隊中元素個數,試給出判別此循環(huán)隊列的隊滿條件,并寫出相應入隊和出隊的算法〔在出隊的算法中要返回隊頭元素〕。請在下劃線處填上正確的語句。
#define m 100
int enqueue(int a[], int rear, int length, int x)
{ if(___________)
{printf(“queue is full〞); return 0;}
27、 rear=(rear+1)% m;
a[rear]=x;
length ___________;
return length; }
int dequeue(int a[], int rear, int length, int *x)
{ if(___________)
{printf(“queueempty〞); return 0;}
*x= a [(rear- length +m)%m];
Length ___________;
return length;
刪除運算是將單鏈表的第i個結點刪去。先在單鏈表中找到 28、第i–1個結點,再刪除其后的結點。具體算法代碼如下所,請在下劃線處填上正確的語句。
template 29、
//查找第i個結點
while(___________jlink;++j;}
if (!q || ___________) throw OutOfBounds( );//沒有第i個結點
p=q–>link;q–>link=p–>link; }
.9. 刪除運算是將單鏈表的第i個結點刪去。先在單鏈表中找到第i–1個結點,再刪除其后的結點。具體算法代碼 如下所示:請在下劃線處填上正確的語句。
template 30、s T>
Line_ListLink 31、=q–>link;++j;}
if (!q || ___________) throw OutOfBounds( );//沒有第i個結點
p=q–>link;q–>link=p–>link; }
x=p–>data;delete p;
return *this;}
串S,1 ≤ pos ≤ Length_Str(S)且0 ≤ len ≤Length_Str(S)–pos+1,用串Sub返回S的自第i個字符起長度為j的子串。請在下劃線處填上正確的語句。
string Sub_Str 32、ing(string &Sub, string S, int i, int j);
{ int p;
Sub.length = 0;
if (i <= 0 || i > S.length || j<= 0 ||___________)
return Sub; //參數錯誤時,返回空串
for(p = i – 1; ___________; p++) //把S.ch[i–1]至S.ch[i–1+j]復制到串Sub中
Sub.ch[p – i +1] = S.ch[p];
Sub.ch[j] ='\0'; ___________ = j;
retu 33、rn Sub; } }
.四.閱讀理解題(描述算法思路,再綜合出其功能)
此題說明:
算法思路指的是對某種數據結構(如,記錄序列), 進展操作(如,移動位置), 的處理步驟(如,1,2,3….).
算法功能指的是要達到的處理目標(如,合并成有序的單鏈表.)
.1. 閱讀如下算法代碼:描述算法思路,再綜合出其功能.
main(){ int i,max,a[10];
printf(“請輸入10個整數:〞);
for(i=0;i<=10;i++)
scanf(“%d〞,&a[i]);
max=a[0];
i=1;
while(i<10)
{ 34、if(a[i]>max)
max=a[i];
i++;}
printf(“值為:〞,max);}
.2. 閱讀如下算法代碼:描述算法思路,再綜合出其功能.
void delete(node *head,int x)
{ node *p,*q; q=head; p=head->next;
while((p!=NULL) && (p->data!=x))
{ q=p; p=p->next; 35、 }
if(p==NULL) printf("未找到x!\n");
else if(q==head)
printf("x為第一個結點,無前趨!\n");
else
{ q->data=x; q->next=p->next; free(p); } }
.3. 閱讀如下算法代碼:描述算法思路,再綜合出其功能.
int InsertPosList(struct List *L, int 36、 pos, ElemType x)
{ int i;
if(pos<1 || pos>L->size+1) /*假如pos越界如此插入失敗*/
return 0;
if(L->size==L->MaxSize) /*重新分配更大的存儲空間*/
againMalloc(L);
for(i=L->size-1; i>=pos-1; i--)
L->list[i+1]=L->list[i];
L->list[pos-1]=x;
L- 37、>size++;
return 1; }
.4.閱讀如下算法代碼:描述算法思路,再綜合出其功能.
void InsertIncreaseList( Seqlist *L , Datatype x )
{? int i;
if ( L->length>=ListSize)
Error(“overflow");
for ( i=L -> length ; i>0 && L->data[ i-1 ] > x ; i--)
L->data[ i ]=L->data[ i ] ; // 38、 比擬并移動元素
L->data[ i ] =x;
L -> length++; }
.5.閱讀如下算法代碼:描述算法思路,再綜合出其功能.
void DeleteList ( LinkList L, DataType min , DataType max )
{ ListNode *p , *q , *s;
p=L;
while( p->next && p->next->data <=min )?
//找比min大的前一個元素位置
p=p->next;
q=p->next;/ 39、/p指向第一個不大于min結點的直接前趨,q指向第一個大于min的結點
while(q &&q->data 40、{ count++; temp = (front+count)%n; Queue[temp]=x; }}
int dequeue()
{ int temp;if(count==0) printf("隊列下溢出\n");
else { temp=Queue[front]; front=(front+1)%n;
count--; return temp; }}
.7..閱讀如下算法代碼:描述算法思路,再綜合出其功能.
Status ListInsert_L(LinkList &L, int i, ElemTy 41、pe e) {
//在帶頭結點的單鏈表L.
p = L; k = 0; //初始化,p指向頭結點,k為計數器
while (p && k < i-1) {//逐步移動指針p,直到p指向第i-1個元素或p為空
p = p->next; ++ k; } // 找到第i-1個元素所在結點
if (!p || k > i-1) return ERROR; //無法插入
if(!(s = (LinkLinst) malloc(sizeof(LNode)))) //申 42、請元素e的結點空間
return OVERFLOW; //內存無空閑單元,無法申請到空間
s->data = e// 申請一個結點s;
s->next = p->next; // 修改s的指針域指向p的下一結點
p->next = s;// 修改p的指針域指向s
return OK;} //LinstInsert_L
.8.下閱讀如下算法代碼:描述算法思路,再綜合出其功能.
Quicskort(Recordnode r[],int low,int high)
/*low和high為記錄序列的
- 溫馨提示:
1: 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
2: 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
3.本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
5. 裝配圖網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。