版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、<p> 《兩個(gè)鏈表的交叉合并》</p><p><b> 課程設(shè)計(jì)論文</b></p><p> 學(xué)生姓名 </p><p> 學(xué) 號(hào) </p><p> 所屬學(xué)院 信息工程學(xué)院 </p><p> 專
2、 業(yè) 計(jì)算機(jī)科學(xué)與技術(shù) </p><p> 班 級(jí) 計(jì)算機(jī) </p><p> 指導(dǎo)教師 </p><p> 教師職稱 講師 </p><p><b> 目 錄</b></p><p><
3、b> 前言1</b></p><p><b> 1.1設(shè)計(jì)背景1</b></p><p> 1.1.1數(shù)據(jù)結(jié)構(gòu)簡(jiǎn)介1</p><p> 1.1.2算法選擇的原因1</p><p> 1.2設(shè)計(jì)的原理和內(nèi)容1</p><p><b> 正文2<
4、;/b></p><p> 2.1課程設(shè)計(jì)目的2</p><p> 2.2課程設(shè)計(jì)題目2</p><p> 2.2.1問(wèn)題定義2</p><p> 2.2.2需求分析2</p><p><b> 2.3總體方案2</b></p><p><b
5、> 2.4運(yùn)行環(huán)境3</b></p><p> 2.5設(shè)計(jì)流程圖3</p><p><b> 2.6設(shè)計(jì)思路3</b></p><p> 2.6.1.1線性表的單鏈表結(jié)構(gòu)4</p><p> 2.6.1.2實(shí)現(xiàn)兩個(gè)鏈表的簡(jiǎn)單合并算法4</p><p> 2.
6、6.1.3把元素插入到鏈表當(dāng)中4</p><p> 2.6.1.4將元素從鏈表中刪除5</p><p> 2.6.2鏈表的合并5</p><p> 2.6.3鏈表的排序6</p><p> 2.6.4算法模塊設(shè)計(jì)7</p><p> 2.7程序運(yùn)行分析10</p><p>
7、<b> 參考文獻(xiàn)11</b></p><p><b> 附錄11</b></p><p><b> 前言</b></p><p><b> 1.1設(shè)計(jì)背景</b></p><p> 1.1.1數(shù)據(jù)結(jié)構(gòu)簡(jiǎn)介</p><p&
8、gt; 數(shù)據(jù)結(jié)構(gòu)是計(jì)算機(jī)程序設(shè)計(jì)的重要理論設(shè)計(jì)基礎(chǔ), 它不僅是計(jì)算機(jī)學(xué)科的核心課程, 而 且成為其他理工專業(yè)的熱門選修課。 數(shù)據(jù)結(jié)構(gòu)是計(jì)算機(jī)存儲(chǔ)、 組織數(shù)據(jù)的方式。 通常情況下, 精心選擇的數(shù)據(jù)結(jié)構(gòu)可以帶來(lái)更高的運(yùn)行或者存儲(chǔ)效率的算法。 比如在計(jì)算機(jī)中央處理器中,CPU接到一個(gè)中斷請(qǐng)求便會(huì)停下當(dāng)前正在執(zhí)行的指令去 處理這個(gè)中斷請(qǐng)求完成中斷操作,&
9、#160;首先要做的就是保護(hù)現(xiàn)場(chǎng)。 保護(hù)現(xiàn)場(chǎng)需要將下一條指令的 地址指針和當(dāng)前指令返回地址等重要的數(shù)據(jù)進(jìn)行存儲(chǔ)。 在眾多的數(shù)據(jù)結(jié)構(gòu)中, 這些重要的數(shù) 據(jù)被存儲(chǔ)到棧這個(gè)數(shù)據(jù)結(jié)構(gòu)中。</p><p> 1.1.2算法選擇的原因</p><p> 在許多類型的程序的設(shè)計(jì)中, 數(shù)據(jù)結(jié)構(gòu)的選擇是一個(gè)基本的設(shè)計(jì)考慮因素。 許多大
10、型系 統(tǒng)的構(gòu)造經(jīng)驗(yàn)表明, 系統(tǒng)實(shí)現(xiàn)的困難程度和系統(tǒng)構(gòu)造的質(zhì)量都嚴(yán)重的依賴于是否選擇了最優(yōu) 的數(shù)據(jù)結(jié)構(gòu)。 許多時(shí)候, 確定了數(shù)據(jù)結(jié)構(gòu)后, 算法就容易得到了。 有些時(shí)候事情也會(huì)反過(guò)來(lái), 我們根據(jù)特定算法來(lái)選擇數(shù)據(jù)結(jié)構(gòu)與之適應(yīng)。 不論哪種情況, 選擇合適的數(shù)據(jù)結(jié)構(gòu)都是非常 重要的。</p><p> 1.2設(shè)
11、計(jì)的原理和內(nèi)容</p><p> 本次程序設(shè)計(jì)采用C語(yǔ)作為描述和實(shí)現(xiàn)算法的程序語(yǔ)言,主要的設(shè)計(jì)思路就是完成對(duì) 鏈表的操作,如鏈表的插入、刪除、取鏈表頂?shù)鹊?,這些操作都是通過(guò)C語(yǔ)言程序來(lái)實(shí)現(xiàn)的。最 后的結(jié)果就是運(yùn)行程序時(shí)能夠完成對(duì)以上設(shè)計(jì)的操作。</p><p><b> 正文</b></p><p> 鏈表是一種物理存
12、儲(chǔ)單元上非連續(xù)、非順序的存儲(chǔ)結(jié)構(gòu),數(shù)據(jù)元素的邏輯順序是通過(guò)鏈表中的指針鏈接次序?qū)崿F(xiàn)的。鏈表由一系列結(jié)點(diǎn)(鏈表中每一個(gè)元素稱為結(jié)點(diǎn))組成,結(jié)點(diǎn)可以在運(yùn)行時(shí)動(dòng)態(tài)生成。每個(gè)結(jié)點(diǎn)包括兩個(gè)部分:一個(gè)是存儲(chǔ)數(shù)據(jù)元素的數(shù)據(jù)域,另一個(gè)是存儲(chǔ)下一個(gè)結(jié)點(diǎn)地址的指針域。 相比于線性表順序結(jié)構(gòu),鏈表比較方便插入和刪除操作。</p><p><b> 2.1課程設(shè)計(jì)目的</b></p><p&g
13、t; 課程設(shè)計(jì)為學(xué)生提供了一個(gè)既動(dòng)手又動(dòng)腦,獨(dú)立實(shí)踐的機(jī)會(huì)將課本上的理論知識(shí)和實(shí)際有機(jī)的結(jié)合起來(lái),鍛煉學(xué)生的分析解決實(shí)際問(wèn)題的能力。提高學(xué)生適應(yīng)實(shí)際,實(shí)踐編程的能力。</p><p><b> 2.2課程設(shè)計(jì)題目</b></p><p> 實(shí)現(xiàn)兩個(gè)鏈表的交叉合并。</p><p> 要求:(1)輸入兩個(gè)鏈表。</p>&l
14、t;p> (2)輸出兩個(gè)鏈表合并后的鏈表。</p><p><b> 2.2.1問(wèn)題定義</b></p><p> 實(shí)現(xiàn)對(duì)兩個(gè)的鏈表的交叉合并,輸出線形表C用直接插入排序法對(duì)C進(jìn)行升序排序,生成鏈表D,并輸出鏈表D。</p><p><b> 2.2.2需求分析</b></p><p>
15、; 鏈表是線性表的鏈?zhǔn)奖硎?,由于它不要求邏輯上相鄰的元素在物理上相鄰,所以它沒有不需要像順序存儲(chǔ)結(jié)構(gòu)在插入,刪除元素時(shí)移動(dòng)大量的元素,只修改指針節(jié)點(diǎn),并修改這些節(jié)點(diǎn)的指針域,查找過(guò)程中需平均一定指針域?yàn)楸黹L(zhǎng)的一半,而采用順序結(jié)構(gòu)存儲(chǔ)線性表,插入和刪除元素操作需要平均移動(dòng)表彰的一半元素。移動(dòng)指針域操作比一動(dòng)元素操作花費(fèi)的時(shí)間少得多。</p><p><b> 2.3總體方案</b><
16、/p><p> 鏈表是一種特殊的線性表,具體表現(xiàn)在它的刪除,插入不用移動(dòng)大量的元素,而且所用時(shí)間較少。這次設(shè)計(jì)的目的在于將它的快速,便捷體現(xiàn)出來(lái)。將程序分為了兩個(gè)部分程序設(shè)計(jì)和程序調(diào)試。首先查閱與鏈表合并有關(guān)的資料和文獻(xiàn);其次設(shè)計(jì)項(xiàng)目的整體構(gòu)架和算法;然后先用一個(gè)門程序設(shè)計(jì)語(yǔ)言進(jìn)行算法的描述;最后調(diào)試程序。</p><p><b> 2.4運(yùn)行環(huán)境</b></p
17、><p> Win7 32位操作系統(tǒng)</p><p> Microsoft Visual C++編譯器</p><p><b> 2.5設(shè)計(jì)流程圖</b></p><p><b> 2.6設(shè)計(jì)思路</b></p><p> 本課程設(shè)計(jì)將對(duì)鏈表的交叉合并和直接插入排
18、序的實(shí)現(xiàn)。首先將兩個(gè)鏈表進(jìn)行交叉合并,合并的要求如下: </p><p> 建立兩個(gè)鏈表A和B,鏈表元素個(gè)數(shù)分別為m和n個(gè)。假設(shè)元素分別為(x1,x2,…xm),和(y1,y2, …yn)。把它們合并成一個(gè)線形表C,使得: </p><p> 當(dāng)m>=n時(shí),C=x1,y1,x2,y2,…xn,yn,…,xm </p><p> 當(dāng)n>m時(shí),C=y1
19、,x1,y2,x2,…ym,xm,…,yn</p><p><b> 輸出線形表C。 </b></p><p> 對(duì)合并的鏈表C進(jìn)行直接插入排序,輸出鏈表D。</p><p><b> 2.6.1鏈表</b></p><p> 2.6.1.1線性表的單鏈表結(jié)構(gòu)</p><
20、p> ElemType data; </p><p> struct Node *next; </p><p><b> } Node; </b></p><p> typedef struct Node *Linklist;</p><p> 2.6.1.2實(shí)現(xiàn)兩個(gè)鏈表的簡(jiǎn)單合并算法</p&g
21、t;<p> Void Mergelist_L(Linklist &La,Linklist &Lb,Linklist &Lc){</p><p> //已知單線性鏈表La和Lb的元素按值非遞減排列。 </p><p> //歸并La和Lb得到新的線性表Lc,Lc的數(shù)據(jù)元素也按非遞減排列。 </p><p> InitLi
22、st(Lc); </p><p> i=j=1;k=0; </p><p> La_len=Listlength(La);Lb_len=ListLength(Lb); </p><p> While((i<=La_len)&&(j<=Lb_len)){//La和Lb均非空 </p><p> Getelem
23、(La, i, ai);Getelem(Lb, j, bj); </p><p> If(ai<=bj){Listinsert(Lc, ++k ai);++i;} </p><p> Else {Listinsert(Lc, ++k bj);++j;} </p><p> } While(i<=La_len){</p><p&g
24、t; Getelem(La, i++, ai);Listinsert(Lc, ++k, ai); </p><p><b> } </b></p><p> While(j<=Lb_len){</p><p> Getelem(Lb, j++, bj);Listinsert(Lc, ++k, bj); </p>&l
25、t;p> }}//Mergelist</p><p> 2.6.1.3把元素插入到鏈表當(dāng)中</p><p> 在鏈表的合并中常用的操作是插入,要在線性表的兩個(gè)元素之間出入一個(gè)新的元素x。為了插入元素x,首先要生成一個(gè)數(shù)據(jù)域?yàn)閤的結(jié)點(diǎn),然后插入數(shù)據(jù)元素x。根據(jù)插入操作的邏輯定義,還要修改結(jié)點(diǎn)a中的指針域,令其指向結(jié)點(diǎn)x,而結(jié)點(diǎn)x中的指針域應(yīng)指向結(jié)點(diǎn)b,從而實(shí)現(xiàn)3個(gè)元素a,b和x之
26、間的邏輯變化。上述指針修改語(yǔ)句描述為,</p><p> s—>next=p—>next;p—>next=s;</p><p> 單鏈表中插入結(jié)點(diǎn)時(shí)的指針變化情況如圖所示: p </p><p> 圖圖圖圖1 1 1 1</p><p> 單鏈表中插入結(jié)點(diǎn)時(shí)的指針變化情
27、單鏈表中插入結(jié)點(diǎn)時(shí)的指針變化情單鏈表中插入結(jié)點(diǎn)時(shí)的指針變化情單鏈表中插入結(jié)點(diǎn)時(shí)的指針變化情 </p><p> 插入元素的代碼如下: </p><p> status ListInsert_L(LinkList &L, int i,ElemType e){ </p><p> //在帶頭結(jié)點(diǎn)的單鏈線性表L中第i個(gè)位置之前插入元素e</p>
28、<p><b> p=l;j=0;</b></p><p> while(p&&j<i-1){p=p->next;++j;}//尋找第i-1個(gè)結(jié)點(diǎn)</p><p> if(!P||j>i-1)return ERROR; //i小于1或者大于表長(zhǎng)+1</p><p> s=(LinkList)
29、malloc(sizeof(LNode)); //生成新結(jié)點(diǎn) </p><p> s->date=e; s->next=p->next; //插入L中 </p><p> p->next=s; </p><p> return OK;</p><p> }//ListInsert_L</p>&
30、lt;p> 2.6.1.4將元素從鏈表中刪除</p><p> 在線性表中刪除元素b時(shí),為了在單鏈表中實(shí)現(xiàn)元素a、b和c之間邏輯關(guān)系的變化,僅需改動(dòng)節(jié)點(diǎn)a中的指針域即可。假設(shè)p為指向節(jié)點(diǎn)a的指針,則修改指針的語(yǔ)句為</p><p> p->next=p->next->next; </p><p> 在已知單鏈表中元素插入或插入或刪除的
31、確切位置的情況下,在單鏈表中插入 刪除一個(gè)結(jié)點(diǎn)時(shí),僅需修改指針而不需要移動(dòng)元素。刪除元素代碼如下:</p><p> Status ListInsert_L(LinkList&L,int I,ElemType e){</p><p> //在帶頭結(jié)點(diǎn)的單鏈表線性表L中,刪除第i個(gè)元素,并由e返回其值 </p><p><b> p=L;j=0
32、;</b></p><p> while (p&&j<i-1){//尋找第i-1個(gè)結(jié)點(diǎn),并令p指向其前驅(qū) </p><p> p=p—>next;+j:</p><p><b> }</b></p><p> If(!(p—>next)||j>i-1)retur
33、n ERROR;//刪除位置不合理 </p><p> q=p—>next;p—>next=q—>next;//刪除并釋放結(jié)點(diǎn) </p><p> e=q—>data; free(q);//釋放函數(shù) </p><p> retrun OK; </p><p> }//ListDelete_L</p>
34、<p> 2.6.2鏈表的合并</p><p> 鏈表的合并是將兩個(gè)鏈表合并成一個(gè)鏈表。假設(shè)兩個(gè)鏈表LA和LB頭指針為L(zhǎng)a,Lb,要?dú)w并La和Lb得到鏈表Lc,pa和pb分別指向La和Lb表中當(dāng)前待比較插入的結(jié)點(diǎn), 而pc指向Lc當(dāng)前最后一個(gè)結(jié)點(diǎn),若pa—>data<pb—>data,則將pa所指結(jié)點(diǎn)鏈接到pc所指結(jié)點(diǎn)之后,,否則將pb所指結(jié)點(diǎn)鏈接到pc所指結(jié)點(diǎn)之后。當(dāng)LA和L
35、B為非空表時(shí),pa和pb分別指向La和Lb表中第一個(gè)結(jié)點(diǎn),否則為空;pc指向空表Lc中的頭結(jié)點(diǎn)。由于鏈表的長(zhǎng)度為隱含的,則第一個(gè)循環(huán)執(zhí)行的條件pa和pb皆非空,當(dāng)其中一個(gè)為空時(shí),說(shuō)明有一個(gè)表的元素已歸并完,則是要將另一個(gè)表的剩余段鏈接在pc所指結(jié)點(diǎn)之在內(nèi)部排序中,如果按照排序過(guò)程中依據(jù)的不同原則進(jìn)行分類,則大致可以分為插入排序、交換排序、選擇排序、歸并排序、和計(jì)數(shù)排序5類。通常在排序過(guò)程中需進(jìn)行一下兩種基本操作:</p>
36、<p> ?。?)比較兩個(gè)關(guān)鍵字的大小; </p><p> ?。?)將記錄從一個(gè)位置轉(zhuǎn)移到另一個(gè)位置。前一個(gè)基本操作是對(duì)于任何排序方法來(lái)說(shuō)都是必要的,而后者可以通過(guò)改變記錄的儲(chǔ)存方式來(lái)來(lái)予以避免。且為了研究方便起見,設(shè)關(guān)鍵字均為整數(shù)。待排序、記錄的數(shù)</p><p> typedef struct{ </p><p> KeyType key;
37、 //關(guān)鍵字項(xiàng)</p><p> InfoType otherinfo; //其他數(shù)據(jù)項(xiàng) </p><p> Typedef struct{ </p><p> RedType r[MSXSIZE+1]; //r[0]閑置或用作哨兵單元 </p><p> Int length;
38、 //順序表長(zhǎng)度 </p><p> }SqList //順序表類型</p><p> 本課程設(shè)計(jì)主要是應(yīng)用直接插入排序?qū)⒑喜⒌逆湵磉M(jìn)行排序。直接插入排序是一種最簡(jiǎn)單的排序方法,他的基本操作是將一個(gè)記錄插入已排好序的有序表中,從而得到一個(gè)新的、數(shù)據(jù)記錄增一得有序表。一般情況下,第i趟直接插入排序的操作為:在含有i-1個(gè)記錄的有序子序列r[1
39、.i-1]中插入一個(gè)記錄r[i]后,變成含有i個(gè)記錄的有序子序列r1.i[];并且和順序表查找類似,在r[0]處設(shè)置監(jiān)視哨。在自i-1起往前收索的過(guò)程中,可以同時(shí)后已記錄。整個(gè)排序過(guò)程為進(jìn)行n-1趟插入,即:先將序列中的第一個(gè)記錄看做一個(gè)有序的子序列,然后從第二個(gè)記錄起逐個(gè)插入,直至整個(gè)序列變成按關(guān)鍵字有序序列為止。</p><p> void InsertSort (SqList&L){
40、 //對(duì)順序表L作直接插入排序。 </p><p> For(i=2;i<=L.length;++i) </p><p> If (LT(L.r[i].Key,L.r[i-1].Key)){ //“(”,需要將L.r[i]插入有序子表 </p><p> L.r[0]=L.r[i] </p><
41、;p> L.r[i]=L.r[i-1]; </p><p> For (j=i-2;LT(L.r[0].Key,L.r[j].Key);--j) </p><p> L.r[j+1]=L.r[j]; //記錄后移 </p><p> L.r[j+1]=L.r[0]; //插入到
42、正確位</p><p><b> }</b></p><p> }//InsertSort</p><p> 2.6.3鏈表的排序</p><p> 排序是計(jì)算機(jī)程序設(shè)計(jì)中的一個(gè)重要操作,他的功能是將一個(gè)數(shù)據(jù)元素(或記錄)的任意序列,重新排列成一個(gè)按關(guān)鍵字有序的序列。由于待排序的記錄數(shù)量不同,使得排序過(guò)程中的存儲(chǔ)
43、器不同,可將排序方法分為兩大類;一類是內(nèi)部排序,指的是待排序記錄存放在計(jì)算機(jī)隨機(jī)存儲(chǔ)器中進(jìn)行的排序過(guò)程。另一類是外部排序,指的是待排序記錄的數(shù)量很大,,以至內(nèi)存一次不能容納全部記錄,在排序過(guò)程中尚需對(duì)外存進(jìn)行訪問(wèn)的排序過(guò)程。 在鏈表的操作中常用到兩個(gè)標(biāo)準(zhǔn)函數(shù)malloc和free。通常,在設(shè)有“指針”數(shù)據(jù)類型的高級(jí)語(yǔ)言中均存在與其相應(yīng)的過(guò)程與函數(shù)。假設(shè)p和q是LinkList型的結(jié)點(diǎn),則執(zhí)行p=(LinkList)malloc(size
44、of(LNode))的作用是由系統(tǒng)生成一個(gè)Lnode型的結(jié)點(diǎn),同時(shí)將該結(jié)點(diǎn)的起始位置賦給指針變量p;反之執(zhí)行free的作用是由系統(tǒng)回收一個(gè)LNode型的結(jié)點(diǎn),,回收后的空間可以備做再次生成結(jié)點(diǎn)時(shí)用。因此,單鏈表和順序存儲(chǔ)不同,它是一種動(dòng)態(tài)結(jié)構(gòu)。整個(gè)可用存儲(chǔ)空間可為多個(gè)鏈表共同享用,每個(gè)鏈表占用的空間不需要預(yù)先分配劃定,而是可以由系統(tǒng)即使生成。因此建立線性表的鏈?zhǔn)酱鎯?chǔ)結(jié)構(gòu)的過(guò)程就是動(dòng)態(tài)生成鏈表的</p><p>
45、 Viod CreateList_L(LinkList&L,int n){</p><p> //逆位序輸入n個(gè)元素的值,建立帶表頭結(jié)點(diǎn)的單鏈線性表L。 </p><p> L=(LinkList)malloc(sizef(LNode)); </p><p> L—>next=NULL;//先建立一個(gè)帶頭節(jié)點(diǎn)的單鏈表 </p>&l
46、t;p> For(i=n;i>n;--i){ </p><p> p=(LinkList)malloc(sizeof(LNode)), //生成新結(jié)點(diǎn) </p><p> scanf(&p—>data); </p><p> p—>next=L—>next;L—>next=p; </p><p
47、><b> } </b></p><p> }//CrateList_L</p><p> 2.6.4算法模塊設(shè)計(jì)</p><p> 2.6.4.1創(chuàng)建鏈表模塊</p><p> 創(chuàng)建鏈表,首先由主函數(shù)輸入要?jiǎng)?chuàng)建的鏈表長(zhǎng)度n,在由主函數(shù)將參數(shù)傳遞到創(chuàng)建鏈表函數(shù)creat,由For循環(huán)控制表節(jié)點(diǎn)的創(chuàng)建,由m
48、alloc函數(shù)開辟新的結(jié)點(diǎn)空間,創(chuàng)建鏈表結(jié)束后,由print函數(shù)將鏈表元素輸出。</p><p> 創(chuàng)建鏈表函數(shù)的實(shí)現(xiàn)代碼如下:</p><p> #include<stdlib.h></p><p> #include<stdio.h></p><p> #include<conio.h><
49、/p><p> #include<malloc.h></p><p> #define L sizeof(struct Node)</p><p> struct Node //結(jié)構(gòu)體</p><p><b> {</b></p><p> long int number;<
50、;/p><p> struct Node *next;</p><p><b> };</b></p><p> struct Node *create(int a)//鏈表創(chuàng)建函數(shù)</p><p><b> { int n;</b></p><p> struct
51、Node *p1, *p2, *head;</p><p> head = NULL;</p><p><b> n = 0;</b></p><p> p2 = p1 = (struct Node *) malloc(L); //分配內(nèi)存</p><p> scanf("%ld", &
52、;p1->number);</p><p> while (a)//錄入鏈表信息</p><p><b> {</b></p><p> n = n + 1;</p><p> if (n == 1)</p><p> head = p1;</p><p>
53、<b> else</b></p><p> p2->next = p1;</p><p><b> p2 = p1;</b></p><p> p1 = (struct Node *) malloc(L);</p><p> if (a != 1)//分配內(nèi)存</p>
54、<p> scanf("%ld", &p1->number);</p><p> a--; //控制輸入的個(gè)數(shù)</p><p><b> }</b></p><p> p2->next = NULL;</p><p> return (head);</p
55、><p> }//鏈表創(chuàng)建函數(shù)結(jié)束</p><p> 2.6.4.2輸出函數(shù)模塊</p><p> 待鏈表輸入完成后,定義單鏈表的頭結(jié)點(diǎn)*p,通過(guò)運(yùn)用一個(gè)循環(huán)語(yǔ)句,將鏈表內(nèi)的元素一一輸出在執(zhí)行程序界面上。</p><p> void print(struct Node *head)//輸出函數(shù)</p><p>&l
56、t;b> {</b></p><p> struct Node *p;</p><p><b> p = head;</b></p><p> printf("數(shù)字:\n");</p><p> if (head != NULL)</p><p>
57、 do //循環(huán)實(shí)現(xiàn)輸出</p><p><b> {</b></p><p> printf("%ld", p->number);</p><p> printf(" ");</p><p> p
58、= p->next;</p><p> } while (p != NULL);</p><p> printf("\n");</p><p><b> }</b></p><p> 2.6.4.3鏈表交叉合并模塊</p><p> struct Node *
59、inter_link(struct Node * chain1, int a, struct Node * chain2, int b) {</p><p><b> int temp;</b></p><p> struct Node *head, *p1, *p2, *pos;</p><p> /*判斷a,b大小并合并 */<
60、/p><p> if (a >= b) {</p><p> head = p1 = chain1;</p><p> p2 = chain2;</p><p> } else/*b>a*/ {</p><p> head = p1 = chain2;</p><p> p2
61、 = chain1;</p><p> temp = a, a = b, b = temp; /*交換a和b*/</p><p><b> }</b></p><p> /*下面把p1的每個(gè)元素插在p2相應(yīng)元素之前,p1長(zhǎng)a,p2長(zhǎng)b*/</p><p> pos = head; /*此時(shí)pos指向p1中的第一個(gè)
62、元素*/</p><p> while (p2 != NULL) {//漂亮,蛇形插入</p><p> p1 = p1->next;</p><p> pos->next = p2;</p><p><b> pos = p2;</b></p><p> p2 = p2-&
63、gt;next;</p><p> pos->next = p1;</p><p><b> pos = p1;</b></p><p><b> }</b></p><p> return head;</p><p><b> }</b>
64、;</p><p> 2.6.4.4鏈表排序模塊</p><p> void InsertSort(struct Node *p, int m)//排序函數(shù)</p><p><b> {</b></p><p> int i, j, t;</p><p> struct Node *k;
65、</p><p><b> k = p;</b></p><p> for (i = 0; i < m - 1; i++) {</p><p> for (j = 0; j < m - i - 1; j++) {</p><p> if (p->number > (p->next)-
66、>number) {</p><p> t = p->number;</p><p> p->number = (p->next)->number;</p><p> (p->next)->number = t;</p><p><b> }</b></p>
67、<p> p = p->next;</p><p><b> }</b></p><p><b> p = k;</b></p><p><b> }</b></p><p><b> }</b></p><
68、p> 2.6.4.5主函數(shù)模塊</p><p> int main()//main函數(shù)</p><p><b> {</b></p><p> struct Node *p1, *p2;</p><p><b> int a;</b></p><p><
69、b> int b;</b></p><p><b> int h;</b></p><p> printf("請(qǐng)輸入第一個(gè)鏈表:\n");</p><p> printf("\n輸入鏈表的長(zhǎng)度a:\n");</p><p> scanf("%d
70、", &a);</p><p> printf("請(qǐng)輸入鏈表數(shù)據(jù):");</p><p> p1 = create(a);</p><p> printf("\n你剛才輸入的第一個(gè)鏈表信息:\n ");</p><p> print(p1);</p><p&
71、gt; printf("\n 請(qǐng)輸入第二個(gè)鏈表:\n");</p><p> printf("\n輸入鏈表的長(zhǎng)度b:\n");</p><p> scanf("%d", &b);</p><p> printf("請(qǐng)輸入鏈表數(shù)據(jù):");</p><p&
72、gt; p2 = create(b);</p><p> printf("\n你剛才輸入的第二個(gè)鏈表的信息:\n");</p><p> print(p2);</p><p> p1 = inter_link(p1, a, p2, b);</p><p> h = a + b;</p><p&
73、gt; printf("\n合并后的鏈表\n:");</p><p> print(p1);</p><p> InsertSort(p1, h);</p><p> printf("\n排序后的鏈表:\n");</p><p> print(p1);</p><p>
74、<b> return 0;</b></p><p><b> }</b></p><p><b> 2.7程序運(yùn)行分析</b></p><p> 打開軟件,根據(jù)提示先輸入鏈表a的長(zhǎng)度,再輸入鏈表a的元素,然后輸出鏈表a。</p><p> 重復(fù)上述步驟輸出鏈表b。&
75、lt;/p><p> 之后程序完成對(duì)鏈表a、b合并,然后輸出鏈表c最后輸出排序后的鏈表.</p><p> 當(dāng)輸入的元素長(zhǎng)度超過(guò)鏈表的長(zhǎng)度是只讀入并輸出與鏈表的長(zhǎng)度相同的元素個(gè)數(shù)。</p><p><b> 總結(jié)</b></p><p> 這幾天的課程設(shè)計(jì),讓我對(duì)以往課堂上學(xué)習(xí)到的理論知識(shí)得到了更深刻的理解,通過(guò)自己
76、設(shè)計(jì)算法,調(diào)試程序一系列操作,最后才能使程序正確無(wú)誤的運(yùn)行,這一系列操作雖然對(duì)于我來(lái)說(shuō)很復(fù)雜困難,但是通過(guò)查閱資料,以及同學(xué)的幫忙最終還是完成了本次課程設(shè)計(jì)。 以往對(duì)于鏈表的問(wèn)題有些一知半解,有些東西也不是特別的明白清楚,有了這次課設(shè)感覺自己把以往認(rèn)為很抽象的問(wèn)題變得更具體,自己親手來(lái)做這次課程設(shè)計(jì),感覺有些明白了《數(shù)據(jù)結(jié)構(gòu)》這門課程其中的奧妙。我做兩個(gè)鏈表的合并,想象起來(lái)并不是特別的困難,用語(yǔ)言很容易的就可以表達(dá)出來(lái),對(duì)于這次課設(shè)就是
77、編寫代碼來(lái)完成這一系列的操作,編寫代碼需要相當(dāng)?shù)募有⌒模粋€(gè)字母的錯(cuò)誤就能導(dǎo)致整個(gè)程序的錯(cuò)誤,所以編寫代碼需要心細(xì)不能馬虎任何一個(gè)小的字母。我經(jīng)過(guò)查閱資料,詢問(wèn)同學(xué),多次的修改程序才使得程序最后的成功運(yùn)行。有了這次課設(shè),不僅讓我對(duì)這門課程有了新的認(rèn)識(shí)和對(duì)知識(shí)的更深刻的理解,同時(shí)也磨練了自己的耐心和毅力。以后學(xué)習(xí)中還需要繼續(xù)努力學(xué)好這門課程。</p><p><b> 參考文獻(xiàn)</b><
78、;/p><p> [1] 葉乃文,鄭曉紅. 數(shù)據(jù)結(jié)構(gòu)[M]. 北京:人民郵電出版社,2001.5:75-90 </p><p> [2] 趙國(guó)玲. C語(yǔ)言與數(shù)據(jù)結(jié)構(gòu)[M]. 北京:電子工業(yè)出版社,1999.11:120-146 </p><p> [3] 嚴(yán)蔚敏,吳偉民. 數(shù)據(jù)結(jié)構(gòu)(C語(yǔ)言版)[M]. 北京:清華大學(xué)出版社,2006.10:44-52 <
79、/p><p> [4] 蔡子經(jīng),施伯樂. 數(shù)據(jù)結(jié)構(gòu)教程[M]. 上海:復(fù)旦大學(xué)出版社,2006.4:168-207</p><p> [5]李春褒.數(shù)據(jù)結(jié)構(gòu)教程(第二版)[M].北京:清華大學(xué)出版社,2007.3:22-46 </p><p> [6] 嚴(yán)蔚敏.數(shù)據(jù)結(jié)構(gòu) C語(yǔ)言[M].北京: 清華大學(xué)出版社,2006.10: 110-135 </p>
80、<p> [7] 嚴(yán)蔚敏,陳文博.數(shù)據(jù)結(jié)構(gòu)及應(yīng)用算法教程[M].北京:清華大學(xué)出版社,2003.6: 121-156 </p><p> [8] 嚴(yán)蔚敏.數(shù)據(jù)結(jié)構(gòu)習(xí)題[M].北京:清華大學(xué)出版社,2002.3: 67-98 </p><p><b> 附錄</b></p><p> #include<stdlib.h
81、></p><p> #include<stdio.h></p><p> #include<conio.h></p><p> #include<malloc.h></p><p> #define L sizeof(struct Node)</p><p> st
82、ruct Node //結(jié)構(gòu)體</p><p><b> {</b></p><p> long int number;</p><p> struct Node *next;</p><p><b> };</b></p><p> struct Node *cr
83、eate(int a)//鏈表創(chuàng)建函數(shù)</p><p><b> {</b></p><p><b> int n;</b></p><p> struct Node *p1, *p2, *head;</p><p> head = NULL;</p><p><
84、;b> n = 0;</b></p><p> p2 = p1 = (struct Node *) malloc(L); //分配內(nèi)存</p><p> scanf("%ld", &p1->number);</p><p> while (a)//錄入鏈表信息</p><p><
85、;b> {</b></p><p> n = n + 1;</p><p> if (n == 1)</p><p> head = p1;</p><p><b> else</b></p><p> p2->next = p1;</p><
86、;p><b> p2 = p1;</b></p><p> p1 = (struct Node *) malloc(L);</p><p> if (a != 1)//分配內(nèi)存</p><p> scanf("%ld", &p1->number);</p><p> a-
87、-; //控制輸入的個(gè)數(shù)</p><p><b> }</b></p><p> p2->next = NULL;</p><p> return (head);</p><p> }//鏈表創(chuàng)建函數(shù)結(jié)束</p><p> void print(struct Node *head)
88、//輸出函數(shù)</p><p><b> {</b></p><p> struct Node *p;</p><p><b> p = head;</b></p><p> printf("數(shù)字:\n");</p><p> if (head !
89、= NULL)</p><p> do//循環(huán)實(shí)現(xiàn)輸出</p><p><b> {</b></p><p> printf("%ld", p->number);</p><p> printf(" ");</p><p> p =
90、p->next;</p><p> } while (p != NULL);</p><p> printf("\n");</p><p><b> }</b></p><p> //鏈表的交叉合并算法</p><p> struct Node * inter_
91、link(struct Node * chain1, int a, struct Node * chain2, int b) {</p><p><b> int temp;</b></p><p> struct Node *head, *p1, *p2, *pos;</p><p> /*判斷a,b大小并合并 */</p>
92、<p> if (a >= b) {</p><p> head = p1 = chain1;</p><p> p2 = chain2;</p><p> } else/*b>a*/ {</p><p> head = p1 = chain2;</p><p> p2 = cha
93、in1;</p><p> temp = a, a = b, b = temp; /*交換a和b*/</p><p><b> }</b></p><p> /*下面把p1的每個(gè)元素插在p2相應(yīng)元素之前,p1長(zhǎng)a,p2長(zhǎng)b*/</p><p> pos = head; /*此時(shí)pos指向p1中的第一個(gè)元素*/&l
94、t;/p><p> while (p2 != NULL) {//漂亮,蛇形插入</p><p> p1 = p1->next;</p><p> pos->next = p2;</p><p><b> pos = p2;</b></p><p> p2 = p2->nex
95、t;</p><p> pos->next = p1;</p><p><b> pos = p1;</b></p><p><b> }</b></p><p> return head;</p><p><b> }</b></
96、p><p> //對(duì)合并好的鏈表進(jìn)行排序</p><p> void InsertSort(struct Node *p, int m)//排序函數(shù)</p><p><b> {</b></p><p> int i, j, t;</p><p> struct Node *k;</p
97、><p><b> k = p;</b></p><p> for (i = 0; i < m - 1; i++) {</p><p> for (j = 0; j < m - i - 1; j++) {</p><p> if (p->number > (p->next)->nu
98、mber) {</p><p> t = p->number;</p><p> p->number = (p->next)->number;</p><p> (p->next)->number = t;</p><p><b> }</b></p><p
99、> p = p->next;</p><p><b> }</b></p><p><b> p = k;</b></p><p><b> }</b></p><p><b> }</b></p><p>&
100、lt;b> //主函數(shù)</b></p><p> int main()//main函數(shù)</p><p><b> {</b></p><p> struct Node *p1, *p2;</p><p><b> int a;</b></p><p&g
101、t;<b> int b;</b></p><p><b> int h;</b></p><p> printf("請(qǐng)輸入第一個(gè)鏈表:\n");</p><p> printf("\n輸入鏈表的長(zhǎng)度a:\n");</p><p> scanf(&q
102、uot;%d", &a);</p><p> printf("請(qǐng)輸入鏈表數(shù)據(jù):");</p><p> p1 = create(a);</p><p> printf("\n你剛才輸入的第一個(gè)鏈表信息:\n ");</p><p> print(p1);</p>
103、<p> printf("\n 請(qǐng)輸入第二個(gè)鏈表:\n");</p><p> printf("\n輸入鏈表的長(zhǎng)度b:\n");</p><p> scanf("%d", &b);</p><p> printf("請(qǐng)輸入鏈表數(shù)據(jù):");</p>
104、<p> p2 = create(b);</p><p> printf("\n你剛才輸入的第二個(gè)鏈表的信息:\n");</p><p> print(p2);</p><p> p1 = inter_link(p1, a, p2, b);</p><p> h = a + b;</p>
105、<p> printf("\n合并后的鏈表\n:");</p><p> print(p1);</p><p> InsertSort(p1, h);</p><p> printf("\n排序后的鏈表:\n");</p><p> print(p1);</p><
溫馨提示
- 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ù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫(kù)僅提供信息存儲(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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 城市鏈表課程設(shè)計(jì)
- 城市鏈表課程設(shè)計(jì)
- 城市鏈表課程設(shè)計(jì)報(bào)告
- 程序設(shè)計(jì)課程設(shè)計(jì)--鏈表操作
- 實(shí)現(xiàn)兩個(gè)鏈表的合并數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---實(shí)現(xiàn)兩個(gè)鏈表的合并
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---雙向鏈表
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-鏈表操作
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---鏈表操作
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告--鏈表
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---鏈表操作
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告---鏈表操作
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)-- 循環(huán)單鏈表
- 數(shù)據(jù)庫(kù)課程設(shè)計(jì)-鏈表的簡(jiǎn)單操作
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)--雙向循環(huán)鏈表的實(shí)現(xiàn)
- 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)---城市鏈表的設(shè)計(jì)與實(shí)現(xiàn)
- 交通設(shè)計(jì)課程設(shè)計(jì)--交叉口改善設(shè)計(jì)
- fpga課程設(shè)計(jì)課程設(shè)計(jì)報(bào)告
- 【課程設(shè)計(jì)】c語(yǔ)言課程設(shè)計(jì)
- 交通課程設(shè)計(jì)--交叉口改善設(shè)計(jì)
評(píng)論
0/150
提交評(píng)論