用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)二叉排序樹全代碼_第1頁
用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)二叉排序樹全代碼_第2頁
用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)二叉排序樹全代碼_第3頁
用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)二叉排序樹全代碼_第4頁
用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)二叉排序樹全代碼_第5頁
已閱讀5頁,還剩31頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、安徽新華學(xué)院安徽新華學(xué)院數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)報(bào)告題目:題目:用順序和二叉樹存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)二叉樹排序用順序和二叉樹存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)二叉樹排序 學(xué)院:學(xué)院:信息工程信息工程 專業(yè):專業(yè):信息與計(jì)算科學(xué)信息與計(jì)算科學(xué) 班級(jí):班級(jí):12 信科本一班信科本一班 姓名:姓名:李智李智 學(xué)號(hào):學(xué)號(hào):1242155110 指導(dǎo)教師:指導(dǎo)教師:李明李明 設(shè)計(jì)時(shí)間:設(shè)計(jì)時(shí)間: 2013-12-16 至至 2013-12-30 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)課程設(shè)計(jì)任務(wù)書一設(shè)計(jì)任務(wù)研究關(guān)于如何創(chuàng)建二叉排序樹并對(duì)樹進(jìn)行遍歷,查找和刪除等操作,同時(shí)關(guān)注用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)帶來的區(qū)別。二設(shè)計(jì)要求(1). 利用順序存儲(chǔ)和

2、鏈?zhǔn)酱鎯?chǔ)兩種算法計(jì)算實(shí)現(xiàn)二叉搜索樹的創(chuàng)建。(2). 利用順序存儲(chǔ)和鏈?zhǔn)酱鎯?chǔ)兩種算法計(jì)算實(shí)現(xiàn)中序遍歷。(3). 利用順序存儲(chǔ)和鏈?zhǔn)酱鎯?chǔ)兩種算法計(jì)算實(shí)現(xiàn)查找結(jié)點(diǎn)。(4). 利用順序存儲(chǔ)和鏈?zhǔn)酱鎯?chǔ)兩種算法計(jì)算實(shí)現(xiàn)刪除結(jié)點(diǎn)。三設(shè)計(jì)期限2013-12-16 至 2013-12-30 數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)前言數(shù)據(jù)結(jié)構(gòu)是一門研究非數(shù)值計(jì)算的程序設(shè)計(jì)問題中計(jì)算機(jī)的操作對(duì)象以及它們之間的關(guān)系和操作等的學(xué)科。本課程設(shè)計(jì)中的二叉排序樹,可以用順序存儲(chǔ)和鏈?zhǔn)酱鎯?chǔ)兩種算法計(jì)算。本課程設(shè)中的二叉排序樹,一共要實(shí)現(xiàn)四項(xiàng)基本的功能。它們分別是二叉搜索樹的創(chuàng)建、中序遍歷、查找結(jié)點(diǎn)和刪除結(jié)點(diǎn)。二叉樹是樹形結(jié)構(gòu)的一個(gè)重要的類型,二叉樹

3、是 n(n=0)個(gè)結(jié)點(diǎn)的有限集,它或者是空集(n=0),或者由個(gè)根結(jié)點(diǎn)及兩棵互不相交的、分別稱作這個(gè)根的左子樹和右子樹的二叉樹組成。 二叉樹的存儲(chǔ)結(jié)構(gòu)和算法比較簡(jiǎn)單,特別適合計(jì)算機(jī)處理。即使一般形式的樹也可簡(jiǎn)單的轉(zhuǎn)換為二叉樹。二叉樹的順序存儲(chǔ)結(jié)構(gòu)是把二叉樹的所有結(jié)點(diǎn),按照一定的次序順序,存儲(chǔ)到一片連續(xù)的存儲(chǔ)單元中。遍歷二叉樹就是沿某有前序遍歷、中條搜索路徑周游二叉樹,對(duì)樹中每個(gè)結(jié)點(diǎn)訪問一次且僅訪問一次。在遍歷方案中主要序遍歷、后序遍歷。 現(xiàn)實(shí)中有許多應(yīng)用到二叉樹的例子,所以我們要把理論與現(xiàn)實(shí)結(jié)合起來。在學(xué)習(xí)中主要掌握怎么求二叉樹的高度、葉子結(jié)點(diǎn)個(gè)數(shù)、總結(jié)點(diǎn)個(gè)數(shù)以及熟練三種遍歷的方法。 數(shù)據(jù)結(jié)構(gòu)

4、課程設(shè)計(jì)目 錄1 1 需求分析需求分析.11.1 問題的提出 .11.2 任務(wù)與分析.12 2 總體設(shè)計(jì)總體設(shè)計(jì).22.1 二叉排序樹的建立.22.2 二叉排序樹的中序遍歷.22.3 二叉排序樹中元素的查找.22.4 二叉排序樹中元素的刪除.32. 5 總體設(shè)計(jì)流程圖3 3 詳細(xì)設(shè)計(jì)詳細(xì)設(shè)計(jì).63.1 中序遍歷模塊 .93.2 刪除模塊 .94 4 編碼與調(diào)試編碼與調(diào)試.124.1 順序存儲(chǔ) .124.2 二叉鏈表存儲(chǔ) .165 5 總結(jié)總結(jié).19總 結(jié).19心得體會(huì).20參考文獻(xiàn)參考文獻(xiàn).21全部代碼全部代碼.22二叉鏈表結(jié)構(gòu)C.22二叉鏈表結(jié)構(gòu)C+ .26順序存儲(chǔ)結(jié)構(gòu)C.29 -1-1 需

5、求分析1.1 問題的提出 研究關(guān)于如何創(chuàng)建二叉排序樹并對(duì)樹進(jìn)行遍歷,查找和刪除等操作,同時(shí)關(guān)注用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)帶來的區(qū)別。1.2 任務(wù)與分析 用順序和二叉鏈表作存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)二叉排序樹:(1)以回車(n)為輸入結(jié)束標(biāo)志,輸入數(shù)列 L,生成一棵二叉排序樹 T;(2)對(duì)二叉排序樹 T 作中序遍歷,輸出結(jié)果;(3)輸入元素 x,查找二叉排序樹 T,若存在含 x 的結(jié)點(diǎn),則刪除該結(jié)點(diǎn),并作中序遍歷(執(zhí)行操作 2);否則輸出信息“無 x” 。2 總體設(shè)計(jì)2.1 二叉排序樹的建立建二叉樹的結(jié)點(diǎn)至少應(yīng)當(dāng)包含三個(gè)域,分別存放結(jié)點(diǎn)的數(shù)據(jù) data,左子女結(jié)點(diǎn)指針 leftChild 和右子女結(jié)點(diǎn)指針 r

6、ightChild。整個(gè)二叉樹的鏈表要有一個(gè)表頭指針,它指向二叉樹的根結(jié)點(diǎn),其作用是當(dāng)作樹的訪問點(diǎn)從空的二叉排序樹開始,經(jīng)過一系列的查找插入操作以后,生成了一棵二叉排序樹。根據(jù)二叉排序樹的定義,建立一棵二叉排序樹的過程是按照待排序序列元素的先后次序,不斷動(dòng)態(tài)生成二叉樹的結(jié)點(diǎn),逐個(gè)插入到二叉樹中。若 p 為根結(jié)點(diǎn)指針,b 為當(dāng)前待插入元素,其過程可以描述為:若為空樹(p=nil) ,動(dòng)態(tài)生成一個(gè)結(jié)點(diǎn),其數(shù)據(jù)域?yàn)楫?dāng)前待插入元素 b,左、右指針域?yàn)椤翱铡?,p 指向該結(jié)點(diǎn)。若非空樹,比較 b 與根結(jié)點(diǎn)數(shù)據(jù) data(p)如果 bdata) *p=t;return (1); else if(keyda

7、ta) searchBST(t-lchild,key,t,p); else searchBST(t-rchild,key,t,p); insertBSTinsertBST 的聲明的聲明 insertBST(node *t,int key) node p=NULL,s=NULL; if(!searchBST(*t,key,NULL,&p) s=(node)malloc(sizeof(BSTnode); s-data=key; s-lchild=s-rchild=NULL; if(!p) *t=s; else if(keydata) p-lchild=s; else p-rchild=s;

8、 -5- return (1); else return (0);inorderTraverseinorderTraverse 類的聲明類的聲明inorderTraverse(node *t) if(*t) if(inorderTraverse(&(*t)-lchild) printf(%d ,(*t)-data); if(inorderTraverse(&(*t)-rchild); return(1) ;DeleteDelete 類的聲明類的聲明node Delete(node t,int key) node p=t,q=NULL,s,f; while(p!=NULL) if

9、(p-data=key) break; q=p; if(p-datakey) p=p-lchild; else p=p-rchild; if(p=NULL) return t; if(p-lchild=NULL) if(q=NULL) t=p-rchild; else -6- if(q-lchild=p) q-lchild=p-rchild; else q-rchild=p-rchild; free(p); else f=p; s=p-lchild; while(s-rchild) f=s; s=s-rchild; if(f=p) f-lchild=s-lchild; else f-rchil

10、d=s-lchild; p-data=s-data; free (s); return t;-7-3.1 中序遍歷模塊系統(tǒng)將提示用戶輸入新添加的數(shù)據(jù),輸入結(jié)束后進(jìn)行中序遍歷關(guān)鍵代碼: inorderTraverse(node *t) /*中序遍歷函數(shù)*/ if(*t) if(inorderTraverse(&(*t)-lchild) /*中序遍歷根的左子樹*/ printf(%d ,(*t)-data); /*輸出根結(jié)點(diǎn)*/ if(inorderTraverse(&(*t)-rchild); /*中序遍歷根的右子樹*/ return(1) ;3.2 刪除模塊系統(tǒng)將對(duì)用戶輸入的數(shù)

11、進(jìn)行查找,查找到之后刪除此數(shù),并對(duì)全部數(shù)據(jù)進(jìn)行中序遍歷。關(guān)鍵代碼:node Delete(node t,int key) /*刪除函數(shù)*/ node p=t,q=NULL,s,f; while(p!=NULL) /*查找要?jiǎng)h除的點(diǎn)*/ if(p-data=key)-8- break; q=p; if(p-datakey) p=p-lchild; else p=p-rchild; if(p=NULL) return t; /*查找失敗*/ if(p-lchild=NULL) /*p 指向當(dāng)前要?jiǎng)h除的結(jié)點(diǎn)*/ if(q=NULL) t=p-rchild; /*q 指向要?jiǎng)h結(jié)點(diǎn)的父母*/ else

12、if(q-lchild=p) q-lchild=p-rchild; /*p 為 q 的左孩子*/ else q-rchild=p-rchild;/*p 為 q 的右孩子*/ free(p); else /*p 的左孩子不為空*/ f=p; s=p-lchild; while(s-rchild) /*左拐后向右走到底*/ f=s; s=s-rchild;-9- if(f=p) f-lchild=s-lchild; /*重接 f 的左子樹*/ else f-rchild=s-lchild; /*重接 f 的右子樹*/ p-data=s-data; free (s);return t;4 編碼與調(diào)試

13、編碼與調(diào)試首先進(jìn)入 VC+6.0,打開工程 zjr.dsw,然后進(jìn)入源程序,也可以不打開工程,直-10-接雙擊 zjr 文件夾下的 zjr.exe 文件即可運(yùn)行程序。4.1 順序存儲(chǔ)圖 7.1.1 打開程序,成功顯示提示信息-11-圖 7.1.2 輸入數(shù)據(jù),以 0 結(jié)束輸入,操作成功圖 7.1.3 功能 1:中序輸出數(shù)據(jù),操作成功-12-圖 7.1.4 功能 2:刪除數(shù)據(jù),顯示提示信息,操作成功-13-圖 7.1.5 刪除數(shù)據(jù),操作成功圖 7.1.6 重復(fù)執(zhí)行程序,操作成功-14-4.2 二叉鏈表存儲(chǔ)圖 7.2.1 打開程序,顯示提示信息,操作成功-15-圖 7.2.2 功能 1:輸入數(shù)據(jù),進(jìn)

14、行中序遍歷,操作成功圖 7.2.3 功能 2:輸入數(shù)據(jù),進(jìn)行刪除,操作失敗,因?yàn)闆]有此數(shù)據(jù),顯示 錯(cuò)誤信息-16-圖 7.2.4 功能 2:輸入數(shù)據(jù),進(jìn)行中序遍歷,操作成功通過上述測(cè)試,本系統(tǒng)實(shí)現(xiàn)了二叉樹的生成,中序遍歷,查找刪除功能,能避免數(shù)據(jù)的輸入錯(cuò)誤等。驗(yàn)證結(jié)果正確,說明其符合算法設(shè)計(jì)的要求:(1)正確性、可讀性、健壯性、效率與低儲(chǔ)存量需求.要寫一個(gè)優(yōu)質(zhì)的算法,就必須考慮其時(shí)間復(fù)雜度(它表示隨問題的規(guī)模 n 的增大,算法執(zhí)行時(shí)間的增長(zhǎng)率和 f(n)的增長(zhǎng)率相同)和空間復(fù)雜度。遍歷二叉樹的算法中的基本操作是訪問結(jié)點(diǎn),則不論按哪一次次序進(jìn)行遍歷,對(duì)含 n 個(gè)結(jié)點(diǎn)的二叉樹,其時(shí)間復(fù)雜度都為 O

15、(n) 。所需空間為遍歷過程中棧的最大容量,即樹的深度,最壞情況下為 n,則空間復(fù)雜度也為 O(n) 。-17-5 5 總結(jié)總結(jié)這次課程設(shè)計(jì)使我對(duì)數(shù)據(jù)結(jié)構(gòu)認(rèn)識(shí)深刻了許多,其中最深刻的是我理解了用二叉鏈表結(jié)構(gòu)存儲(chǔ)實(shí)現(xiàn)二叉排序樹,同時(shí)也加深了對(duì)二叉樹的理解。本課程設(shè)計(jì)實(shí)現(xiàn)了二叉排序樹的創(chuàng)建、中序遍歷、刪除二叉排序樹中某個(gè)結(jié)點(diǎn),。在進(jìn)行搜索時(shí),還可以采用更好的搜索結(jié)構(gòu)即動(dòng)態(tài)搜索結(jié)構(gòu)。當(dāng)沒有找到時(shí),可以將其插入,而不是僅僅提示未找到。通過這一次的課程設(shè)計(jì),我已經(jīng)會(huì)用二叉鏈表存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)對(duì)二叉排序樹的的創(chuàng)建,中序遍歷,查找和某個(gè)刪除結(jié)點(diǎn)等基本操作。但我同時(shí)也發(fā)現(xiàn)了自己許多不足之處 。首先,對(duì)數(shù)據(jù)結(jié)構(gòu)的掌

16、握還不夠。雖然完成了程序,但是只用到了基本的結(jié)點(diǎn)以及鏈表,在數(shù)據(jù)結(jié)構(gòu)的選擇上避重就輕,覆蓋面較小,不能很好的體現(xiàn)各種數(shù)據(jù)結(jié)構(gòu)的掌握度,同時(shí)也缺少了適當(dāng)?shù)腻憻?,在這方面還需要自己主動(dòng)去提高。其次,在程序整體的設(shè)計(jì)上還不夠完善,各模塊可以適當(dāng)增加內(nèi)容,界面還可以更加的人性化些,這樣整個(gè)程序才具有更強(qiáng)的美觀性與實(shí)用性??偠灾?,這次課程設(shè)計(jì)給了我很大啟發(fā),我明白了,不管遇到什么問題,只要抓住根源,不氣餒,從不同方面去攻破它,終究會(huì)成功,生活也是如此。在今后的工作、學(xué)習(xí)中我將認(rèn)真總結(jié)經(jīng)驗(yàn)教訓(xùn),努力使自己成為一名技術(shù)過硬、工作嚴(yán)謹(jǐn)、思維活躍的工程人員,為提高人們的生活質(zhì)量做出更大的貢獻(xiàn)。-18-心得體會(huì)

17、課程設(shè)計(jì)結(jié)束了,在這次的課程設(shè)計(jì)中不僅檢驗(yàn)了我所學(xué)的知識(shí),也培養(yǎng)了我如何去把握一件事情,如何去做一件事情,課程設(shè)計(jì)是我們專業(yè)課程知識(shí)綜合應(yīng)用的實(shí)踐訓(xùn)練是我們邁向社會(huì),從事職業(yè)工作前一個(gè)必不可少的過程。我這次設(shè)計(jì)的科目是數(shù)據(jù)結(jié)構(gòu),數(shù)據(jù)結(jié)構(gòu),是一門研究非數(shù)值計(jì)算的程序設(shè)計(jì)問題中計(jì)算機(jī)的操作對(duì)象(數(shù)據(jù)元素)以及它們之間的關(guān)系和運(yùn)算等的學(xué)科,而且確保經(jīng)過這些運(yùn)算后所得到的新結(jié)構(gòu)仍然是原來的結(jié)構(gòu)類型。這次通過對(duì)二叉排序樹的深入研究,我又一次的溫習(xí)了 c,c+和數(shù)據(jù)結(jié)構(gòu)的有關(guān)知識(shí),盡管這中間經(jīng)歷好多困難,但我通過查找多種資料,利用網(wǎng)絡(luò)優(yōu)勢(shì),完成了任務(wù)。我這次課程設(shè)計(jì)代碼中主要使用了鏈表的循環(huán)和遍歷這兩種操

18、作。循環(huán)鏈表是單鏈表的另一種形式。遍歷是指沿著某條收索路線,依次對(duì)樹中每個(gè)節(jié)點(diǎn)均作一次且僅作一次訪問。通過這次的課程設(shè)計(jì),更是讓我深刻認(rèn)識(shí)到自己在學(xué)習(xí)中的不足,同時(shí)也找到了克服這些不足的方法,這是一筆很大的資源。在以后的學(xué)習(xí)中,我們應(yīng)該利用更多的時(shí)間去上機(jī)實(shí)驗(yàn),加強(qiáng)自學(xué)的能力、多編寫程序,相信不久以后我們的編程能力都會(huì)有很大的提高,能創(chuàng)作出更多更完善更有新意的作品出來。-19-參考文獻(xiàn)1 譚浩強(qiáng) 編著. 程序設(shè)計(jì). 北京:清華大學(xué)出版社,2000 2 王珊珊,張志航 編著. C+程序設(shè)計(jì)教程. 北京:機(jī)械工業(yè)出版社,20113 嚴(yán)蔚敏,吳偉民 編著. 數(shù)據(jù)結(jié)構(gòu). 北京:清華大學(xué)出版社,2001

19、-20-全部代碼全部代碼二叉鏈表結(jié)構(gòu)二叉鏈表結(jié)構(gòu) c#include#includetypedef struct Tnode int data; /*輸入的數(shù)據(jù)*/ struct Tnode *lchild,*rchild; /*結(jié)點(diǎn)的左右指針,分別指向結(jié)點(diǎn)的左右孩子*/ *node,BSTnode;searchBST(node t,int key,node f,node *p) /*查找函數(shù)*/ if(!t)*p=f;return (0); /*查找不成功*/else if(key=t-data) *p=t;return (1); /*查找成功*/ else if(keydata) sear

20、chBST(t-lchild,key,t,p); /*在左子樹中繼續(xù)查找*/else searchBST(t-rchild,key,t,p); /*在右子樹中繼續(xù)查找*/insertBST(node *t,int key) /*插入函數(shù)*/ node p=NULL,s=NULL; if(!searchBST(*t,key,NULL,&p) /*查找不成功*/ s=(node)malloc(sizeof(BSTnode); s-data=key; s-lchild=s-rchild=NULL; if(!p) *t=s; /*被插結(jié)點(diǎn)*s 為新的根結(jié)點(diǎn)*/ else if(keydata)

21、 p-lchild=s;/*被插結(jié)點(diǎn)*s 為左孩子*/ else p-rchild=s; /*被插結(jié)點(diǎn)*s 為右孩子*/ return (1); else -21-return (0);/*樹中已有關(guān)鍵字相同的結(jié)點(diǎn),不再插入*/ inorderTraverse(node *t) /*中序遍歷函數(shù)*/ if(*t) if(inorderTraverse(&(*t)-lchild) /*中序遍歷根的左子樹*/ printf(%d ,(*t)-data); /*輸出根結(jié)點(diǎn)*/ if(inorderTraverse(&(*t)-rchild); /*中序遍歷根的右子樹*/ return

22、(1) ;node Delete(node t,int key) /*刪除函數(shù)*/ node p=t,q=NULL,s,f; while(p!=NULL) /*查找要?jiǎng)h除的點(diǎn)*/ if(p-data=key) break; q=p; if(p-datakey) p=p-lchild; else p=p-rchild; if(p=NULL) return t; /*查找失敗*/ if(p-lchild=NULL) /*p 指向當(dāng)前要?jiǎng)h除的結(jié)點(diǎn)*/ if(q=NULL) t=p-rchild; /*q 指向要?jiǎng)h結(jié)點(diǎn)的父母*/ else if(q-lchild=p) q-lchild=p-rchil

23、d; /*p 為 q 的左孩子*/ else q-rchild=p-rchild;/*p 為 q 的右孩子*/ free(p); else /*p 的左孩子不為空*/ f=p; s=p-lchild; while(s-rchild) /*左拐后向右走到底*/ f=s; s=s-rchild; if(f=p) f-lchild=s-lchild; /*重接 f 的左子樹*/-22- else f-rchild=s-lchild; /*重接 f 的右子樹*/ p-data=s-data; free (s); return t;void main() node T=NULL; int num; in

24、t s=0,j=0,i=0; int ch=0; node p=NULL; printf(輸入一串?dāng)?shù),每個(gè)數(shù)以空格分開:); do scanf(%d,&num); if(!num) printf(完成輸入!n); else insertBST(&T,num); while(num); printf(n 1: 中序輸出); printf(n 2: 輸入元素); while(ch=ch) scanf(%d,&ch); switch(ch) case 0: exit(0); /*0退出*/ case 1: printf( 中序遍歷輸出結(jié)果為:n ); inorderTrave

25、rse(&T); /*1中序遍歷*/ break; case 2: printf( 輸入元素 x,查找二叉排序樹 T,若存在含 x 的結(jié)點(diǎn),則刪除該結(jié)點(diǎn),并作中序遍歷,否則輸出無 x :); scanf(%d,&num); /*3刪除某個(gè)結(jié)點(diǎn)*/ if(searchBST(T,num,NULL,&p) T=Delete(T,num); printf( 刪除成功!中序遍歷輸出:n ); inorderTraverse(&T);-23- else printf( 無%d,num); break; default: printf(無此結(jié)點(diǎn)n); break; /*輸入

26、無效字符*/ -24-二叉鏈表結(jié)構(gòu)二叉鏈表結(jié)構(gòu) c+#include using namespace std;class nodepublic: node(int i):data(i),left(NULL),right(NULL) void inorder(node *&root) /中序遍歷,符合升序輸出 if(root!=NULL) inorder(root-left); coutdataright); void insert(node *&ptr,int item) /在查找樹中插入元素 if(ptr=NULL) ptr=new node(item); else if(i

27、temdata) insert(ptr-left,item); else insert(ptr-right,item); node *find(node *&ptr,int item) /在查找樹中查找元素,找到返回所在結(jié)點(diǎn)指針,找不到返回空指針。 if(ptr=NULL) return NULL; if(ptr-data=item) return ptr; else if(itemdata) find(ptr-left,item); else find(ptr-right,item); node *&findy(node *&ptr,int item) /在查找樹中查

28、找肯定存在的元素,并返回其引用 if(ptr-data=item) return ptr; else if(itemdata)-25- findy(ptr-left,item); else findy(ptr-right,item); node* rl()return left; node* rr()return right; void dele(node *&ptr) /刪除值為 item 所在結(jié)點(diǎn) if(ptr-rl()=NULL&ptr-rr()=NULL) ptr=NULL; else if(ptr-rr()=NULL) ptr=ptr-rl(); else ptr=p

29、tr-rr(); private: int data; node *left; /左孩子結(jié)點(diǎn) node *right; /右孩子結(jié)點(diǎn);int main() int t,i=0,j; coutt; cout輸入tj; node *x=new node(j); for(;ij; x-insert(x,j); coutinorder(x); /作中序遍歷 coutn 輸入操作(當(dāng)輸入-1 時(shí)程序結(jié)束):j; while(j!=-1) node *t=x-find(x,j); /定位結(jié)點(diǎn) if(t!=NULL) node *&y=x-findy(x,j);-26- x-dele(y); cou

30、tinorder(x); else cout無j; coutn 輸入操作(當(dāng)輸入-1 時(shí)程序結(jié)束):j; return 0;-27-順序存儲(chǔ)結(jié)構(gòu)順序存儲(chǔ)結(jié)構(gòu) c#includestdio.h#includemalloc.h#includewindows.h#define endflag 999999#define N 1000int bN;typedef struct int data;int other;int flag1;Link;void Build(Link aN)int w,i,j,k; for(i=0;i=N;i+) ai.flag1=0; ai.data=0; printf(nt

31、tt 請(qǐng)輸入樹的根結(jié)點(diǎn):);scanf(%d,&a1.data);a1.flag1=1;printf(nttt 請(qǐng)輸入結(jié)點(diǎn)個(gè)數(shù):);scanf(%d,&k);for(j=1;j=k;j+)printf(nttt 請(qǐng)輸入結(jié)點(diǎn)的數(shù)值:);scanf(%d,&w);printf(nttt 第%d 位:%d,j,w);a0.data=w;a0.flag1=1;i=1;if(a0.dataai.data)loop:if(a2*i.flag1=0) -28- a2*i.data=a0.data;a2*i.flag1=a0.flag1;if(a2*i.flag1=1)i=2*i;if

32、(a0.dataai.data)goto loop1; if(a0.dataai.data) loop1:if(a2*i+1.flag1=0) a2*i+1.data=a0.data;a2*i+1.flag1=a0.flag1;if(a2*i+1.flag1=1)i=2*i+1;if(a0.dataai.data)goto loop1; void Sdel(Link aN)int i;int flag=0;int q;int number=1;int j=1;int bN;printf(nttt 請(qǐng)輸入需要?jiǎng)h除的結(jié)點(diǎn)的數(shù)值:);scanf(%d,&q);for(i=1;i=N;i+)i

33、f(ai.data=q)ai.data=0;-29-printf(nttt 已刪除%d:,q);flag=1;for(i=1;i=N;i+)if(ai.data!=0)bj=ai.data;j+;number+;for(i=1;i=N;i+)ai.flag1=0;ai.data=0;a1.data=b1;a1.flag1=1;for(j=2;j=number-1;j+)a0.data=bj;a0.flag1=1;i=1;if(a0.dataai.data)loop:if(a2*i.flag1=0) a2*i.data=a0.data;a2*i.flag1=a0.flag1; if(a2*i.f

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論