下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、#include #include#include#define LIST_INIT_SIZE 100#define LISTINCREMENT 10typedef int Elemtype;typedef int Status;typedef structElemtype *elem;int length;int listsize;SqList; /定義順序表類型Status InitList_Sq(SqList &L) /初始化順序表L.elem=(Elemtype *)malloc(LIST_INIT_SIZE* sizeof(Elemtype);L.length=0;L.listsiz
2、e=LIST_INIT_SIZE;return 1;void CreateList(SqList &L) /創(chuàng)建順序表int i;printf(請輸入你要創(chuàng)建的順序表元素個數(shù) );scanf(%d,&L.length);printf(請輸入你要創(chuàng)建的順序表:n);for(i=0;iL.length;i+)scanf(%d,&L.elemi);void print( SqList &L)/輸出順序表int i;for(i=0;iL.length;i+)printf(%3d,L.elemi);Status location( SqList L,Elemtype e)/查找元素的位置int i=0;
3、while(L.elemi!=e & iL.length)return -1;elsereturn i+1;/因為c語言是從下標0開始的當i=0時實際上是順序表的第i+1個元素Status ListInsert_Sq(SqList &L,int i,Elemtype e)/在順序表的第i個位置插入值為e的元素Elemtype *newbase,*q,*p;if(iL.length+1)return 0;if(L.length=L.listsize)newbase=(Elemtype *)realloc(L.elem,(L.listsize+LISTINCREMENT)* sizeof(Elem
4、type);L.elem=newbase;L.listsize+=LISTINCREMENT;q=&(L.elemi-1);for(p=&(L.elemL.length-1);p=q;-p)*(p+1)=*p;*q=e;+L.length;return 1;Status ListDelect_Sq(SqList &L,int i,Elemtype e)/在順序表的第i個位置刪除值為e的元素并返回e的值Elemtype *q,*p;if(iL.length)return 0;p=&(L.elemi-1);e=*p;q=L.elem+L.length-1;for(+p;p=q;+p)*(p-1)=
5、*p;-L.length;return 1;void Combine(SqList La,SqList Lb,SqList &Lc)/將兩個非遞減的順序表合并成一個順序表,合并后元素也按值非遞減排列 Elemtype *pa_last,*pb_last,*pa,*pb,*pc; pa=La.elem; pb=Lb.elem; Lc.listsize=Lc.length=La.length+Lb.length; pc= Lc.elem=(Elemtype *)malloc(Lc.listsize* sizeof(Elemtype); pa_last=La.elem+La.length-1;pb_
6、last=Lb.elem+Lb.length-1;while(pa=pa_last & pb=pb_last)if(*pa= *pb)*pc+=*pa+;else*pc+=*pb+;while(pa=pa_last)*pc+=*pa+;while(pb=pb_last)*pc+=*pb+;void main()SqList la,lb,lc,ld;int i,j;Elemtype e; InitList_Sq(la);CreateList(la);print(la);printf(請輸入要查找的元素:n);scanf(%d,&e);j=location(la,e);printf(該元素的位置為%dn,j);printf(請輸入要插入的位置和元素:n);scanf(%d%d,&i,&e);ListInsert_Sq(la,i,e);printf(輸出插入后的順序表:n);print(la);printf(請輸入要刪除的位置:n);scanf(%d,&i);ListDelect_Sq(la,i,e);printf(刪除的那個元素是:%dn,e);printf(輸出刪除后的順序表:n);print(la);InitList_Sq(lb);CreateList(lb);print(l
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025版高考英語一輪復習第3部分人與自然主題群2環(huán)境保護主題語境1自然環(huán)境自然遺產(chǎn)保護教師用書教案
- 【核心素養(yǎng)目標】第三單元雪域天音 《獻上最潔白的哈達》教學設計 人音版初中音樂八年級上冊
- 7 混合與分離 教學設計-2024-2025學年科學三年級上冊教科版
- 《天安門廣場》(教學設計)-2024-2025學年北師大版數(shù)學六年級上冊
- 《制作二維碼》教案-2024-2025學年青島版(2024)小學信息技術第四冊
- 會計的考試內(nèi)容有哪些
- 小班責任協(xié)議書家長
- 托管合作方案合同
- 聯(lián)達租車合同模板
- 機械中途終止合同模板
- 外派員工與駐外工作管理制度
- 湘教版八年級上冊數(shù)學期中考試試卷及答案
- 循證醫(yī)學智慧樹知到答案2024年浙江中醫(yī)藥大學
- MBA考試《英語》歷年真題和解析答案
- 中國普通食物營養(yǎng)成分表(修正版)
- 中醫(yī)護理進修總結(jié)匯報
- 統(tǒng)編版(2024新版)七年級上冊道德與法治學科教學計劃
- GB/T 44206-2024館藏文物病害數(shù)據(jù)庫建設規(guī)范
- 番茄工作法課件
- 2024時事政治試題庫(附含答案)
- 2024-2030年中國跑道系統(tǒng)行業(yè)市場發(fā)展趨勢與前景展望戰(zhàn)略分析報告
評論
0/150
提交評論