線索二叉樹

線索二叉樹即從前、中、后序三種遍歷中其中一種來看,樹中的左右孩子都不會是空著的,都會指向對應的前驅和后驅。 以中序遍歷為例,二叉樹線索化過程如下: 先是樹的結構

typedef struct ThreadNode{Elemetype data;struct ThreadNode *lchild,*rchild;int ltag,rtag;
}ThreadNode,*ThreadTree;
void InThread(ThreadTree &p,ThreadTree &pre){//記錄當前節點和前驅節點if(p!=NULL){InThread(p->lchild,pre);//先看左子樹if(p->lchild==NULL){//對左孩子進行修改p->lchild=pre;p->ltag = 1;}if(pre!=NULL&&pre->rchild==NULL){//對右孩子進行修改pre->rchild=p;pre->rtag=1;}pre = p;//在下次搜索前及時修改前驅InThread(p->rchild,pre);//看右子樹}
}

將樹進行線索化

void CreateInThread(ThreadTree T){ThreadTree pre = NULL;if(T!=NULL){InThread(T,pre);pre->rchild = NULL;pre->rtag = 1;//對最后一個節點進行修改}
}

接下來是遍歷線索樹

ThreadNode *Firstnode(ThreadNode *p){while(p->ltag==0) p = p->lchild;return p;
}//找出左下第一個節點ThreadNode *Nextnode(ThreadNode *p){if(p->rtag = 0) return Firstnode(p->rchild);else return p->rchild;
}//尋找下一個節點void vist(ThreadNode *p){printf("%d",p->data);
}void Inorder(ThreadNode *T){for(ThreadNode *p = Firstnode(T);p!=NULL;p = Nextnode(p))vist(p);
}

本文由博客一文多發平臺 OpenWrite 發布!

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/714801.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/714801.shtml
英文地址,請注明出處:http://en.pswp.cn/news/714801.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

微服務面試題之套路一

面試題 一、你的項目是從SpringBoot演進到微服務架構的,你在此過程中有調研過哪些技術,怎么調研落地的? 微服務通信框架: 需要選擇適合項目的微服務通信框架,如Dubbo、Spring Cloud或gRPC Feign RestTemplate 等。調研方式可以是…

高性能通信之Netty

一, 同步IO(BIO)模型的架構 一般針對性能不高的情況下可以使用. 二,異步IO(NIO)模型的架構 多路復用(epoll模型):

【LeetCode:124. 二叉樹中的最大路徑和 + 二叉樹+遞歸】

🚀 算法題 🚀 🌲 算法刷題專欄 | 面試必備算法 | 面試高頻算法 🍀 🌲 越難的東西,越要努力堅持,因為它具有很高的價值,算法就是這樣? 🌲 作者簡介:碩風和煒,…

前端開發人員如何做好SEO

前端開發人員如何做好SEO SEO工作不僅限于專業人員。前端開發者也可以在日常開發中實施一些代碼層面的SEO優化。 以下是一些前端常用的SEO方法: 設置合理的title、keywords、description title、keywords、description對SEO至關重要,需貼合頁面內容編…

Codeforces Round 931 (Div. 2) (A~B)

比賽:Codeforces Round 931 (Div. 2) (A~B) 目錄:A B A題:Too Min Too Max 標簽: 構造算法(constructive algorithms)貪心(greedy)數學(math) 題目大意 對數組 a 找到…

【力扣hot100】刷題筆記Day19

前言 回溯回溯回溯!早上整理檔案竟然用了桶排序,不愧是算法狂魔們 79. 單詞搜索 - 力扣(LeetCode) DFS class Solution:def exist(self, board: List[List[str]], word: str) -> bool:m, n len(board), len(board[0])# used…

mysql timestamp轉換為datetime

MySQL timestamp轉換為datetime的方法 1. 流程概述 在MySQL中,timestamp和datetime是兩種不同的數據類型。timestamp存儲了日期和時間,并且會自動更新,可以用于記錄數據的創建和修改時間。datetime則是一個固定的日期和時間,不會自…

談談高并發系統的設計方法論

談談高并發系統的設計方法論 何為高并發系統?什么是并發(Conurrent)?什么是高并發(Hight Concurrnet)?高并發的衡量指標有哪些? 實現高并發系統的兩大板塊高并發系統應用程序側的設計…

騰訊云學生服務器使用教程_申請騰訊云學生機詳細流程

2024年騰訊云學生服務器優惠活動「云校園」,學生服務器優惠價格:輕量應用服務器2核2G學生價30元3個月、58元6個月、112元一年,輕量應用服務器4核8G配置191.1元3個月、352.8元6個月、646.8元一年,CVM云服務器2核4G配置842.4元一年&…

還在用Jenkins?快來試試這款簡而輕的自動部署軟件!

最近發現了一個比 Jenkins 使用更簡單的項目構建和部署工具,完全可以滿足個人以及一些小企業的需求,分享一下。 Jpom 是一款 Java 開發的簡單輕量的低侵入式在線構建、自動部署、日常運維、項目監控軟件。 日常開發中,Jpom 可以解決下面這些…

Nginx的多線程支持探究

文章中心思想: Nginx本身并不直接支持多線程處理模型。它采用的是基于事件驅動的單線程或多進程架構,而非多線程模型。然而,通過Nginx的模塊和第三方擴展,可以實現類似多線程的并發處理效果。 詳細說明: Nginx,作為一款高性能的Web服務器和反向代理服務器,其架構和并發…

章節二、three.js開發入門與調試設置02;

一、軌道控制器查看物體; 1、基本概念 軌道控制器(OrbitControls)可以使得相機圍繞目標進行軌道運動; 2、代碼樣例 // 七、創建軌道控制器(相機圍繞著物體捕捉視角) const controls new OrbitControls(c…

吳恩達機器學習全課程筆記第五篇

目錄 前言 P80-P85 添加數據 遷移學習 機器學習項目的完整周期 公平、偏見與倫理 P86-P95 傾斜數據集的誤差指標 決策樹模型 測量純度 選擇拆分方式增益 使用分類特征的一種獨熱編碼 連續的有價值特征 回歸樹 前言 這是吳恩達機器學習筆記的第五篇&#xff0c…

《2023跨境電商投訴大數據報告》發布|亞馬遜 天貓國際 考拉海購 敦煌網 阿里巴巴

2023年,跨境電商API接口天貓國際、京東國際和抖音全球購以其強大的品牌影響力和市場占有率,穩坐行業前三的位置。同時,各大跨境電商平臺消費糾紛問題層出不窮。依據國內知名網絡消費糾紛調解平臺“電訴寶”(315.100EC.CN&#xff…

javaEE--后端環境變量配置

目錄 pre 文件準備 最終運行成功結果 后端運行步驟 1.修改setenv文件 2.運行setenv,設置環境變量 3.查看jdk版本 4.修改mysql文件夾下的my文件 前端運行步驟 1.nodejs環境配置 2.查看node和npm版本 3.下載并運行npm 4.注冊登錄 pre 文件準備 最終運行…

VR轉接器:破解虛擬與現實邊界的革命性設備

VR轉接器,這一革命性的設備,為虛擬現實體驗帶來了前所未有的自由度。它巧妙地連接了虛擬與現實,使得用戶在享受VR眼鏡帶來的奇幻世界的同時,也能自由地在現實世界中活動。這一設計的誕生,不僅解決了VR眼鏡續航的瓶頸問…

2、云原生安全之可視化界面rancher的部署

文章目錄 1、rancher的部署1.1、安裝rancher1.2、配置k8s2、部署helm3、容器安全工具neuvector此時已經部署好了k8s,使用rancher來管理 rancher簡化了使用k8s的流程,可以圖形化管理k8s。 參考: https://blog.51cto.com/u_15343792/5000311https://docs.rancher.cn/docs/ra…

你們團隊是否有RocketMQ創建Topic、GID創建規范呢

這里是weihubeats,覺得文章不錯可以關注公眾號小奏技術 背景 早期在使用RocketMQ的時候,系統和開發人員不算多。所以topic的創建會非常隨意,各種千奇百怪的topic 比如: order_topic、ORDER_TOPIC、order-topic 各種奇奇怪怪的風格,用_的&a…

GO結構體

1. 結構體 Go語言可以通過自定義的方式形成新的類型,結構體就是這些類型中的一種復合類型,結構體是由零個或多個任意類型的值聚合成的實體,每個值都可以稱為結構體的成員。 結構體成員也可以稱為“字段”,這些字段有以下特性&am…

JS清空數組方法

清空數組的方法有多種,以下是幾種常見的方式: 1.使用 array.length 屬性將數組的長度設為0,這樣會移除數組中的所有元素: var arr [1, 3, 5]; arr.length 0; console.log(arr); // [] 2. 使用 array.splice() 方法,…