下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第C++如何將二叉搜索樹轉(zhuǎn)換成雙向循環(huán)鏈表(雙指針或數(shù)組)目錄二叉搜索樹轉(zhuǎn)換成雙向循環(huán)鏈表二叉搜索樹與雙向鏈表(C++中等區(qū))解題思路代碼展示
二叉搜索樹轉(zhuǎn)換成雙向循環(huán)鏈表
本文解法基于性質(zhì):二叉搜索樹的中序遍歷為遞增序列。
將二叉搜索樹轉(zhuǎn)換成一個(gè)排序的循環(huán)雙向鏈表,其中包含三個(gè)要素:
1.排序鏈表:節(jié)點(diǎn)應(yīng)從小到大排序,因此應(yīng)使用中序遍歷
2.從小到大訪問樹的節(jié)點(diǎn)。雙向鏈表:在構(gòu)建相鄰節(jié)點(diǎn)的引用關(guān)系時(shí),設(shè)前驅(qū)節(jié)點(diǎn)pre和當(dāng)前節(jié)點(diǎn)cur,
不僅應(yīng)構(gòu)建pre.right=cur,也應(yīng)構(gòu)建cur.left=pre。
3.循環(huán)鏈表:設(shè)鏈表頭節(jié)點(diǎn)head和尾節(jié)點(diǎn)tail,則應(yīng)構(gòu)建head.left=tail和tail.right=head。
雙指針:
classSolution{
private:
Node*head,*pre=NULL;
public:
Node*treeToDoublyList(Node*root){//雙指針做法
if(!root)returnNULL;
inorder(root);
head-left=pre;
pre-right=head;
returnhead;
voidinorder(Node*root)
if(root==NULL)return;
inorder(root-left);
root-left=pre;
if(pre)
pre-right=root;
elsehead=root;
pre=root;
inorder(root-right);
數(shù)組方法:很簡單就不做介紹了,就是先把節(jié)點(diǎn)都放進(jìn)數(shù)組然后在建立聯(lián)系。
Node*treeToDoublyList(Node*root){
if(!root)returnNULL;
vectorNode*nodelist;
inorder(nodelist,root);
intl=nodelist.size();
if(l==1)
nodelist[0]-right=nodelist[0];
nodelist[0]-left=nodelist[0];
returnnodelist[0];
for(inti=1;il-1;i++){
nodelist[i]-left=nodelist[i-1];
nodelist[i]-right=nodelist[i+1];
nodelist[0]-left=nodelist[l-1];
nodelist[0]-right=nodelist[1];
nodelist[l-1]-right=nodelist[0];
nodelist[l-1]-left=nodelist[l-2];
returnnodelist[0];
voidinorder(vectorNode*nodelist,Node*root)
if(root==NULL)return;
inorder(nodelist,root-left);
nodelist.push_back(root);
inorder(nodelist,root-right);
二叉搜索樹與雙向鏈表(C++中等區(qū))
題目:輸入一棵二叉搜索樹,將該二叉搜索樹轉(zhuǎn)換成一個(gè)排序的循環(huán)雙向鏈表。要求不能創(chuàng)建任何新的節(jié)點(diǎn),只能調(diào)整樹中節(jié)點(diǎn)指針的指向。
為了讓您更好地理解問題,以下面的二叉搜索樹為例:
我們希望將這個(gè)二叉搜索樹轉(zhuǎn)化為雙向循環(huán)鏈表。鏈表中的每個(gè)節(jié)點(diǎn)都有一個(gè)前驅(qū)和后繼指針。對于雙向循環(huán)鏈表,第一個(gè)節(jié)點(diǎn)的前驅(qū)是最后一個(gè)節(jié)點(diǎn),最后一個(gè)節(jié)點(diǎn)的后繼是第一個(gè)節(jié)點(diǎn)。
下圖展示了上面的二叉搜索樹轉(zhuǎn)化成的鏈表。head表示指向鏈表中有最小元素的節(jié)點(diǎn)。
特別地,我們希望可以就地完成轉(zhuǎn)換操作。當(dāng)轉(zhuǎn)化完成以后,樹中節(jié)點(diǎn)的左指針需要指向前驅(qū),樹中節(jié)點(diǎn)的右指針需要指向后繼。還需要返回鏈表中的第一個(gè)節(jié)點(diǎn)的指針。
解題思路
本文解法基于性質(zhì):二叉搜索樹的中序遍歷為遞增序列。
將二叉搜索樹轉(zhuǎn)換成一個(gè)排序的循環(huán)雙向鏈表,其中包含三個(gè)要素:
排序鏈表:節(jié)點(diǎn)應(yīng)從小到大排序,因此應(yīng)使用中序遍歷從小到大訪問樹的節(jié)點(diǎn);雙向鏈表:在構(gòu)建相鄰節(jié)點(diǎn)(設(shè)前驅(qū)節(jié)點(diǎn)pre,當(dāng)前節(jié)點(diǎn)cur)關(guān)系時(shí),不僅應(yīng)pre.right=cur,也應(yīng)cur.left=pre。循環(huán)鏈表:設(shè)鏈表頭節(jié)點(diǎn)head和尾節(jié)點(diǎn)tail,則應(yīng)構(gòu)建head.left=tail,和tail.right=head。
代碼展示
代碼如下:
classSolution{
public:
Node*treeToDoublyList(Node*root){
if(!root)returnNULL;
mid(root);
//進(jìn)行頭節(jié)點(diǎn)和尾節(jié)點(diǎn)的相互指向,這兩句的順序也是可以顛倒的
head-left=pre;
pre-right=head;
returnhead;
voidmid(Node*cur)
if(!cur)return;
mid(cur-left);
//pre用于記錄雙向鏈表中位于cur左側(cè)的節(jié)點(diǎn),即上一次迭代中的cur,當(dāng)pre==null時(shí),cur左側(cè)沒有節(jié)點(diǎn),即此時(shí)cur為雙向鏈表中的頭節(jié)點(diǎn)
if(pre==NULL)head=cur;
//反之,pre!=null時(shí),cur左側(cè)存在節(jié)點(diǎn)pre,需要進(jìn)行pre.right=cur的操作。
elsepre-right=cur;
//pre是否為null對這句沒有影響,且這句放在上面兩句ifelse之前也是可以的。
cur-left=pre;
//pre指向當(dāng)前的cur
pre=cur;
//全部迭代完成后,pre指向雙向鏈表中的尾節(jié)點(diǎn)
mid(c
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(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ǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2026年湖南勞動(dòng)人事職業(yè)學(xué)院單招職業(yè)傾向性測試題庫及答案1套
- 2026年哈爾濱應(yīng)用職業(yè)技術(shù)學(xué)院單招職業(yè)適應(yīng)性測試模擬測試卷及答案1套
- 2025廣東省疾病預(yù)防控制中心招聘科研助理1人(公共基礎(chǔ)知識)測試題附答案
- 2026寧波市江北區(qū)面向2026屆高校畢業(yè)生招聘高層次和緊缺人才13人筆試參考題庫及答案解析
- 2025年甘肅省定西市隴西縣福星中心衛(wèi)生院高塄分院招聘鄉(xiāng)村醫(yī)生(公共基礎(chǔ)知識)綜合能力測試題附答案
- 2026中國安能集團(tuán)科工有限公司招聘6人筆試參考題庫及答案解析
- 2025河南省人力資源開發(fā)中心有限公司招聘1人考試題庫附答案
- 2025年甘肅省隴南師范學(xué)院第二批高層次人才和急需緊缺專業(yè)技術(shù)人才引進(jìn)(20人)參考題庫附答案
- 2025廣東廣州市天河區(qū)靈秀小學(xué)招聘英語教師1人(學(xué)校自籌經(jīng)費(fèi))考試歷年真題匯編附答案
- 2025年保山市部分醫(yī)療衛(wèi)生事業(yè)單位招聘博士研究生(10人)筆試備考題庫附答案
- 廣東省大灣區(qū)2023-2024學(xué)年高一上學(xué)期期末生物試題【含答案解析】
- 第四單元地理信息技術(shù)的應(yīng)用課件 【高效課堂+精研精講】高中地理魯教版(2019)必修第一冊
- 魯科版高中化學(xué)必修一教案全冊
- 提高隧道初支平整度合格率
- 2023年版測量結(jié)果的計(jì)量溯源性要求
- 建筑能耗與碳排放研究報(bào)告
- GB 29415-2013耐火電纜槽盒
- 中國古代經(jīng)濟(jì)試題
- 軟件定義汽車:產(chǎn)業(yè)生態(tài)創(chuàng)新白皮書
- 磷石膏抹灰專項(xiàng)施工方案
- 水電水利工程施工質(zhì)量管理培訓(xùn)講義
評論
0/150
提交評論