版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、精選優(yōu)質(zhì)文檔-傾情為你奉上1、順序表基本操作的實(shí)現(xiàn)問(wèn)題描述 在順序表中查找值為x的元素的位置,在線性表的某個(gè)位置插入一個(gè)元素,刪除線性表某個(gè)位置的元素?;疽?要求建立生成順序表,可以鍵盤上讀取元素,用順序存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)存儲(chǔ)。實(shí)現(xiàn)提示 要實(shí)現(xiàn)基本操作,可用實(shí)現(xiàn)的基本操作,也可設(shè)計(jì)簡(jiǎn)單的算法實(shí)現(xiàn)。建議步驟1)建立順序表的存儲(chǔ)結(jié)構(gòu);2)利用1)的存儲(chǔ)結(jié)構(gòu)建立有實(shí)際數(shù)據(jù)的數(shù)據(jù)表;3)實(shí)現(xiàn)查找操作;4)實(shí)現(xiàn)插入操作;5)實(shí)現(xiàn)刪除操作。6)寫出main函數(shù)測(cè)試上述操作。實(shí)驗(yàn)源碼:#include <stdio.h>#define MAX 300typedef int ElemType;typ
2、edef structElemType dataMAX;int length;SqList;SqList L;/打印菜單void menu() printf("*n");printf(" 順序表操作的驗(yàn)證實(shí)驗(yàn)n");printf("*n");printf(" 1、初始化表n");printf(" 2、創(chuàng)建表n");printf(" 3、按值查詢n");printf(" 4、在指定位置插入一個(gè)元素n");printf(" 5、刪除指定位置上的一個(gè)元
3、素n");printf(" 6、輸出表n");printf(" 0、退出n");printf("*n");/初始化表,置表長(zhǎng)為0void Init(SqList *L)L->length=0;/創(chuàng)建表void Creat(SqList *L)int n,i;printf("請(qǐng)確定表的長(zhǎng)度:");scanf("%d",&n);L->length=n;printf("請(qǐng)輸入數(shù)據(jù)元素:n"); for(i=1;i<=n;i+)scanf(&quo
4、t;%d",&L->datai);printf("nn按任意任意鍵繼續(xù).n");getch();/顯示列表void PrintL(SqList *L)int i;if(L->length=0)printf("空表,請(qǐng)首先創(chuàng)建表!n");elseprintf("n當(dāng)前表元素是:n");for(i=1;i<=L->length;i+)printf("%d ",L->datai);if(i%10=0) printf("n");printf("n
5、");printf("nn按任意任意鍵繼續(xù).n");getch();/按值查詢void Search(SqList *L)int i,x;printf("請(qǐng)輸入要查詢?cè)氐闹担?quot;);scanf("%d",&x);for(i=1;i<=L->length&&L->datai!=x;i+);if(i<=L->length)printf("n元素%d第一次出現(xiàn)在表中第%d個(gè)位置上!n",x,i);else printf("n表中沒(méi)有元素 %d !n
6、",x);printf("n");printf("nn按任意任意鍵繼續(xù).n");getch();/在指定位置上插入一個(gè)元素void Insert(SqList *L)int i,j,x;printf("請(qǐng)確定要插入的位置:");scanf("%d",&i); printf("請(qǐng)輸入要插入的元素值:");scanf("%d",&x);if(L->length>MAX)printf("表滿!n");return;if(i&
7、lt;1|i>L->length+1)printf("位置錯(cuò)!n");elsefor(j=L->length;j>=i;j-)L->dataj+1=L->dataj;L->datai=x;L->length+; PrintL(L);printf("nn插入成功!按任意任意鍵繼續(xù).n");getch();/刪除指定位置上的一個(gè)元素void Del(SqList *L)int i,j;printf("請(qǐng)確定要?jiǎng)h除元素的位置:");scanf("%d",&i);if
8、(L->length=0)printf("空表!n");elseif(i<1|i>L->length)printf("位置錯(cuò)!n");elsefor(j=i+1;j<=L->length;j+)L->dataj-1 = L->dataj;L->length-; PrintL(L);printf("nn刪除成功!按任意任意鍵繼續(xù).n");getch();main()int t;while(1)system("cls");menu();printf("請(qǐng)選
9、擇一個(gè)操作:");scanf("%d",&t);switch(t)case 1: Init(&L);break;case 2: Creat(&L);break;case 3: Search(&L);break;case 4: Insert(&L);break;case 5: Del(&L);break;case 6: PrintL(&L);break;case 0:exit(0);default:printf("輸入錯(cuò)誤!請(qǐng)按任意鍵繼續(xù).n"); getchar();運(yùn)行截圖:2、有序順序
10、表的合并問(wèn)題描述 已知順序表la和lb中的數(shù)據(jù)元素按非遞減有序排列,將la和lb表中的數(shù)據(jù)元素,合并成為一個(gè)新的順序表lc。基本要求 lc中的數(shù)據(jù)元素仍按非遞減有序排列,并且不破壞la和lb表。實(shí)驗(yàn)源碼:#include <stdio.h>#define MAX 200typedef int ElemType;typedef structElemType dataMAX;int length;SqList;SqList La,Lb,Lc;/初始化表void Init_List(SqList *L)L->length=0;/創(chuàng)建表void Creat_List(SqList *
11、L)int n,i;printf("請(qǐng)確定表的長(zhǎng)度:");scanf("%d",&n);L->length=n;printf("請(qǐng)輸入數(shù)據(jù)元素:n"); for(i=1;i<=n;i+)scanf("%d",&L->datai);/輸出表void Print_List(SqList *L)int i;if(L->length=0)printf("空表,請(qǐng)首先創(chuàng)建表!n");elseprintf("n當(dāng)前表元素是:n");for(i=1;
12、i<=L->length;i+)printf("%d ",L->datai);if(i%10=0) printf("n");printf("n");/從表中取值void GetElem(SqList *L,int i,ElemType *e)if(i>=1&&i<=L->length)*e=L->datai;/插入:void Insert_List(SqList *L,int i,ElemType e)int j;if(L->length>MAX)printf(&q
13、uot;表滿!n");return;if(i<1|i>L->length+1)printf("位置錯(cuò)!n");elsefor(j=L->length;j>=i;j-)L->dataj+1=L->dataj;L->datai=e;+L->length;/合成新表void MergeList()int i,j;ElemType ai,bj;int k=0;i=j=1; while (i<=La.length)&&(j<=Lb.length) / La和Lb均非空 GetElem(&
14、;La,i,&ai); GetElem(&Lb,j,&bj); if (ai<=bj) Insert_List(&Lc,+k,ai); +i; else Insert_List(&Lc,+k,bj); +j; while (i<=La.length)GetElem(&La, i+, &ai);Insert_List(&Lc, +k,ai); while (j<=Lb.length) GetElem(&Lb,j+,&bj);Insert_List(&Lc,+k,bj); Lc.length=La.length+Lb.l
溫馨提示
- 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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 新高考英語(yǔ)二輪復(fù)習(xí)講練測(cè)語(yǔ)法填空綜合 (測(cè)試)(原卷版)
- 建筑勞務(wù)資質(zhì)合同(2篇)
- 產(chǎn)業(yè)園裝修合同范本
- 展覽館改造居間服務(wù)
- 主題餐廳裝修項(xiàng)目文本
- 交通運(yùn)輸項(xiàng)目貸款居間協(xié)議
- 天文館裝修工程模板
- 美妝產(chǎn)品物流配送協(xié)議
- 倉(cāng)儲(chǔ)物流中心建設(shè)運(yùn)輸合同
- 個(gè)人工程設(shè)備運(yùn)輸協(xié)議
- 計(jì)算機(jī)應(yīng)用基礎(chǔ)
- 建設(shè)工程質(zhì)量檢測(cè)方案-技術(shù)標(biāo)部分
- 全國(guó)人工智能應(yīng)用技術(shù)技能大賽理論考試題庫(kù)大全-下(多選、判斷題匯總)
- 初探在數(shù)學(xué)教學(xué)中如何培養(yǎng)學(xué)生的科學(xué)素養(yǎng)
- 配電網(wǎng)項(xiàng)目后評(píng)價(jià)實(shí)施辦法
- 胸痛鑒別診斷
- 汽車行業(yè)各種縮寫(共7頁(yè))
- 摩托車車架的焊接
- 防火封堵設(shè)計(jì)說(shuō)明及施工大樣圖
- 外研(一起)五年級(jí)上冊(cè)期中模擬測(cè)試英語(yǔ)試卷(附答案)
- 鋼材質(zhì)量檢驗(yàn)工中級(jí)資料
評(píng)論
0/150
提交評(píng)論