數(shù)據(jù)結(jié)構(gòu)上機試題教育試題

上傳人:仙*** 文檔編號:34973431 上傳時間:2021-10-24 格式:DOC 頁數(shù):22 大小:131.50KB
收藏 版權(quán)申訴 舉報 下載
數(shù)據(jù)結(jié)構(gòu)上機試題教育試題_第1頁
第1頁 / 共22頁
數(shù)據(jù)結(jié)構(gòu)上機試題教育試題_第2頁
第2頁 / 共22頁
數(shù)據(jù)結(jié)構(gòu)上機試題教育試題_第3頁
第3頁 / 共22頁

下載文檔到電腦,查找使用更方便

10 積分

下載資源

還剩頁未讀,繼續(xù)閱讀

資源描述:

《數(shù)據(jù)結(jié)構(gòu)上機試題教育試題》由會員分享,可在線閱讀,更多相關(guān)《數(shù)據(jù)結(jié)構(gòu)上機試題教育試題(22頁珍藏版)》請在裝配圖網(wǎng)上搜索。

1、數(shù)據(jù)結(jié)構(gòu)上機試題一、 順序表的操作(1)插入元素操作:將新元素x插入到順序表a中第i個位置。(2)刪除元素操作:刪除順序表a中第i個元素。#include#include#define MAX 100;typedef structint data100;int length;sqlist;void init(sqlist &a)/線性表初始化 a.length=0;void insert(sqlist &a ,int i,int x)/ 插入元素操作int j;if(ia.length+1|a.length=100);elsefor(j=a.length+1;ji;j-)a.dataj=a.d

2、ataj-1;a.dataj=x;a.length+; void deleted(sqlist &a ,int i)/ 刪除元素操作int j;if(ia.length);elsefor(j=i;ja.length;j+)a.dataj=a.dataj+1;a.length-;void main() sqlist a;/線性表為a int i,e,x,n,j,s;/i插入位置,e動態(tài)建線性表要用,X插入元素,n表長 init(a);/構(gòu)造一個空表 coutn; cout輸入表長為 n 個數(shù): ; for(j=0;je; insert(a,j,e); cout插入前: ; for(j=0;ja.

3、length ;j+) couta.dataj ; couti; coutx; cout打算在第i個位置插入元素x ; insert(a,i-1,x);/由于從0開始,要構(gòu)造顯示從一開始,所以減1 cout插入后結(jié)果: ; for(j=0;ja.length;j+) couta.dataj ; couts; deleted(a,s-1);/由于從0開始,要構(gòu)造顯示從一開始,所以減1 cout刪除后結(jié)果: ; for(j=0;ja.length;j+) couta.dataj ;二、單鏈表的操作(1)創(chuàng)建一個帶頭結(jié)點的單鏈表;(2)插入元素操作:將新元素x插入到單鏈表中第i個元素之后;(3)刪除

4、元素操作:刪除單鏈表中值為x的元素;#include#includetypedef struct LNodeint data;struct LNode *next;LNode;/創(chuàng)建一個帶頭結(jié)點的長度長度長度為n的鏈表L;void createlist(LNode *&L ,int n)int i;LNode *p;L=(LNode *)malloc(sizeof(LNode);L-next=NULL;for(i=1;i=n;i+)p=(LNode *)malloc(sizeof(LNode);cout請輸入鏈表第ip-data;p-next=L-next;L-next=p;/插入元素操作:將

5、新元素x插入到單鏈表L中第i個元素之后void insert(LNode *&L ,int i,int x)int j=0;LNode *p,*q;p=L;while(p-next!=NULL)j+;if(j=i)q=(LNode *)malloc(sizeof(LNode);/找到位置q-data=x;/放入數(shù)據(jù)q-next=p-next;p-next=q;break;p=p-next;if(p-next=NULL)q=(LNode *)malloc(sizeof(LNode);/找到位置q-data=x;/放入數(shù)據(jù)q-next=p-next;p-next=q;/刪除元素操作:刪除單鏈表中值

6、為x的元素;void deleted(LNode *&L ,int x)LNode *p,*q;p=L;while(p-next!=NULL)if(p-next-data=x)q=p-next;p-next=p-next-next;free(q);p=p-next;void print(LNode *&L)LNode *p;p=L-next;while(p!=NULL)coutdatanext;void main()LNode * L,*p;/節(jié)點為Lint i,x,y,s,n;/i插入位置,X插入元素,y為刪除元素,n表長coutn;createlist(L,n);cout輸出插入之前:;p

7、rint(L);couti;coutx;insert(L,i,x);cout輸出插入后:;print(L);couty;deleted(L,y);/刪除元素操作:刪除單鏈表中值為y的元素;cout輸出刪除后:;print(L);三、在順序棧上實現(xiàn)將非負十進制數(shù)轉(zhuǎn)換成二進制數(shù)#include#include#define MAX 100/在順序棧上實現(xiàn)將非負十進制數(shù)x轉(zhuǎn)換成二進制數(shù)void conversion(int &x)int stackMAX;int top=-1;int t;while(x)stack+top=x%2;x=x/2;while(top!=-1)t=stacktop-;co

8、utt;void main()int x,t;cout請輸入你要轉(zhuǎn)換的非負十進制數(shù)x:x;cout輸出轉(zhuǎn)換后的二進制數(shù):;conversion(x);coutendl;四、在順序表中采用順序查找算法和折半查找算法尋找關(guān)鍵字X在順序表中的位置。#include#include#define MAX 100/在順序表中采用順序查找算法和折半查找算法尋找關(guān)鍵字X在順序表中的位置typedef struct int dataMAX;int length;sqlist;void init(sqlist &a)/線性表初始化 a.length=0;void insert(sqlist &a ,int i,

9、int x)/ 插入元素操作int j;if(ia.length+1|a.length=100);elsefor(j=a.length+1;ji;j-)a.dataj=a.dataj-1;a.dataj=x;a.length+; int search(sqlist &sq,int x)/順序查找算法int i;for(i=0;isq.length;i+)/順序表存儲從0開始if(sq.datai=x)return i;int hsearch(sqlist &sq,int low,int high,int x)/折半查找算法int mid;while(lowx)high=mid-1;else i

10、f(sq.datamidx)low=mid+1;void main() sqlist sq;/線性表為sq int i,e,x,y,n;/i插入位置,x,y要查找元素,n表長 init(sq);/構(gòu)造一個空表 coutn; cout輸入表長為 n 個數(shù): ; for(i=0;ie; insert(sq,i,e); cout查找前(便于判斷):endl; for(i=0;isq.length ;i+) coutsq.datai ; coutendl; cout采用順序查找算法: endl; coutendl; coutx; coutendl; cout關(guān)鍵字x在順序表中的位置為search(sq

11、,x)+1endl; /下表從0開始,+1顯示時,轉(zhuǎn)化成從1開始了 cout采用折半查找算法: endl; coutendl; couty; coutendl; cout關(guān)鍵字y在順序表中的位置為hsearch(sq,1,sq.length,y)+1endl; 五、將無序數(shù)列使用直接插入排序算法和快速排序算法將其排成遞增有序數(shù)列。#include#include#define MAX 100/將無序數(shù)列使用直接插入排序算法和快速排序算法將其排成遞增有序數(shù)列typedef struct int dataMAX;int length;sqlist;void init(sqlist &a)/線性表初

12、始化 a.length=0;void insert(sqlist &a ,int i,int x)/ 插入元素,構(gòu)造無序數(shù)列int j;if(ia.length+1|a.length=100);elsefor(j=a.length+1;ji;j-)a.dataj=a.dataj-1;a.dataj=x;a.length+; /將哨兵放在a.datan中,被排序的記錄放在a.data0.n-1中,直接插入排序算法。void insertsort(sqlist &a)/直接插入排序算法int i,j;int n=a.length;for(i=n-2;i=0;i-) if(a.dataia.data

13、i+1) a.datan=a.datai;/a.datan是哨兵 j=i+1; do a.dataj-1=a.dataj; j+;while(a.dataja.datan);a.dataj-1=a.datan;int Partition(sqlist &a,int i,int j)int pivot=a.datai;while(ij)while(i=pivot) j-; if(ij) a.datai+=a.dataj; while(ij&a.datai=pivot) i+; if(ij) a.dataj-=a.datai; a.datai=pivot; return i;void QuickS

14、ort(sqlist &a,int low,int high)/快速排序 int pivotpos; /劃分后的基準記錄的位置if(lowhigh)/僅當區(qū)間長度大于1時才須排序pivotpos=Partition(a,low,high); QuickSort(a,low,pivotpos-1); QuickSort(a,pivotpos+1,high); void main() sqlist sq1,sq2;/線性表為sq1,sq2 int i,e,x,n1,n2;/n表長 init(sq1);/構(gòu)造一個空表 coutn1; cout輸入表長為 n1 個數(shù): ; for(i=0;ie; in

15、sert(sq1,i,e);/ 插入元素,構(gòu)造無序數(shù)列 cout無序數(shù)列為:endl; for(i=0;isq1.length ;i+) coutsq1.datai ; coutendl; insertsort(sq1); cout直接插入排序后數(shù)列為:endl; for(i=0;isq1.length ;i+) coutsq1.datai ; coutendl; coutendl; coutendl; init(sq2);/構(gòu)造一個空表 coutn2; cout輸入表長為 n2 個數(shù): ; for(i=0;ie; insert(sq2,i,e);/ 插入元素,構(gòu)造無序數(shù)列 cout無序數(shù)列為:endl; for(i=0;isq2.length ;i+) coutsq2.datai ; coutendl; QuickSort(sq2,0, n2-1); cout快速排序后數(shù)列為:endl; for(i=0;isq2.length ;i+) coutsq2.datai ; coutendl;22借鑒試題

展開閱讀全文
溫馨提示:
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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號:ICP2024067431-1 川公網(wǎng)安備51140202000466號


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺,本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請立即通知裝配圖網(wǎng),我們立即給予刪除!