C語言遞歸實現二叉樹(二叉鏈表)的三種遍歷和銷毀操作(實驗)

今天寫的是二叉樹操作的實驗,這個實驗有三個部分:

①建立二叉樹,采用二叉鏈表結構

②先序、中序、后續遍歷二叉樹,輸出節點值

③銷毀二叉樹

?

二叉樹的節點結構定義

typedef struct BiTNode                           //二叉樹的節點結構
{char data;                                             //此處用char  因為數據設用字母struct BiTNode * Lchild, * Rchild;          //左右孩子指針
} BiTree;

  

基本操作函數定義部分

BiTree * CreateBiTree(BiTree * T);             //創建二叉樹
void PreOrderT(BiTree * T);                      //先序遍歷
void InOrderT(BiTree * T);                       //中序遍歷
void PostOrder(BiTree * T);                      //后序遍歷
void DestroyBiTree(BiTree * T);                //銷毀二叉樹

  

?函數實現部分

BiTree * CreateBiTree(BiTree * T)
{char ch;scanf("%c",&ch);if(ch=='#')return 0;                                       //輸入#表示為空節點//因為傳進來的參數是一個樹節點的指針,所以下面這句代碼可以理解成實例化該指針指向的樹節點T =(BiTree *)malloc(sizeof(BiTree));T->data=ch;                                     //給節點的數據域賦值T->Lchild=CreateBiTree(T->Lchild);   //遞歸創建左子樹T->Rchild=CreateBiTree(T->Rchild);  //遞歸創建右子樹return T;
}
void PreOrderT(BiTree * T)
{if(T)                                                   //如果該樹節點存在{printf("%c",T->data);                         //先序遍歷PreOrderT(T->Lchild);PreOrderT(T->Rchild);}
}
void InOrderT(BiTree * T)
{if(T)                                                    //如果該樹節點存在{InOrderT(T->Lchild);                         //中序遍歷printf("%c",T->data);InOrderT(T->Rchild);}
}
void PostOrder(BiTree * T)
{if(T)                                                  //如果該樹節點存在{PostOrder(T->Lchild);PostOrder(T->Rchild);printf("%c",T->data);}
}
void DestroyBiTree(BiTree * T)
{if(T)                                          //如果T存在{DestroyBiTree(T->Lchild);DestroyBiTree(T->Rchild);free(T);}
}

  

?

主函數測試部分

int main(void)
{BiTree * T;   //先定義一個樹節點指針,指向第一個樹節點,也就是根節點printf("請輸入二叉樹的數據,并以#為空節點\n");T=CreateBiTree(T);printf("該樹的先序遍歷結果為:");PreOrderT(T);printf("\n");printf("該樹的中序遍歷結果為:");InOrderT(T);printf("\n");printf("該樹的后序遍歷結果為:");PostOrder(T);printf("\n");DestroyBiTree(T);return 0;
}

  效果圖

好了,這天真冷。。。呼呼

gg,又不夠字數,老規矩,湊字數

山不在高,有仙則名。水不在深,有龍則靈。斯是陋室,惟吾德馨。苔痕上階綠,草色入簾青。談笑有鴻儒,往來無白丁。可以調素琴,金經。絲竹亂耳,案牘之勞形。南陽諸葛廬,西蜀子云亭。孔子云:何陋之有?

轉載于:https://www.cnblogs.com/yellowgg/p/7856950.html

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

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

相關文章

OC extern和變量

注意&#xff1a; extern只能用來聲明全部變量&#xff0c;不能拿來定義變量 #include <stdio.h>// 第一種做法是將a定義在main函數的前面 // int a;// 完整地聲明全部變量a // extern int a;// extern是可以省略的 int a;int a;int a;int a;void test();int main(int ar…

leetcode514. 自由之路(dp)

電子游戲“輻射4”中&#xff0c;任務“通向自由”要求玩家到達名為“Freedom Trail Ring”的金屬表盤&#xff0c;并使用表盤拼寫特定關鍵詞才能開門。 給定一個字符串 ring&#xff0c;表示刻在外環上的編碼&#xff1b;給定另一個字符串 key&#xff0c;表示需要拼寫的關鍵…

java實現遞歸算法_如何在Java中實現二進制搜索算法而無需遞歸

java實現遞歸算法by javinpaul由javinpaul 流行的二進制搜索算法的迭代實現&#xff0c;用于在排序數組中查找元素。 (An Iterative implementation of the popular binary search algorithm to find an element in a sorted array.) Hello everyone! I have published a lot …

Django 入門項目案例開發(中)

關注微信公眾號&#xff1a;FocusBI 查看更多文章&#xff1b;加QQ群&#xff1a;808774277 獲取學習資料和一起探討問題。 昨天已經描述了如何搭建Django的開發環境&#xff0c;今天描述業務流程&#xff0c;具體我們要實現一個什么樣的業務&#xff1b; 以下的業務都是假設的…

縱橫公路造價軟件學習_通遼分公司組織開展2020年 養護工程造價預算培訓

為進一步提高養護員工業務水平和業務素質&#xff0c;提升熟練掌握信息化公路工程造價預算&#xff0c;11月5日&#xff0d;11月8日期間,通遼分公司組織開展了2020年養護工程造價預算培訓。養護科全體人員、基層所站統計人員共計16人參加培訓。本次培訓邀請了縱橫公路工程造價管…

java 生成二維碼

一步一步用 java 設計生成二維碼 轉至 http://blog.sina.com.cn/s/blog_5a6efa330102v1lb.html 在物聯網的時代&#xff0c;二維碼是個很重要的東西了&#xff0c;現在無論什么東西都要搞個二維碼標志&#xff0c;唯恐落伍&#xff0c;就差人沒有用二維碼識別了。也許有一天生分…

leetcode 922. 按奇偶排序數組 II(雙指針)

給定一個非負整數數組 A&#xff0c; A 中一半整數是奇數&#xff0c;一半整數是偶數。 對數組進行排序&#xff0c;以便當 A[i] 為奇數時&#xff0c;i 也是奇數&#xff1b;當 A[i] 為偶數時&#xff0c; i 也是偶數。 你可以返回任何滿足上述條件的數組作為答案。 示例&a…

機器學習 深度學習 ai_如何突破AI炒作成為機器學習工程師

機器學習 深度學習 aiI’m sure you’ve heard of the incredible artificial intelligence applications out there — from programs that can beat the world’s best Go players to self-driving cars.我敢肯定&#xff0c;您已經聽說過令人難以置信的人工智能應用程序-從可…

arcgis插值不覆蓋區劃圖_ArcGIS繪圖—空氣質量站點數據插值繪制等值線圖

作者&#xff1a;吳琳&#xff1b;陳天舒&#xff0c;山東大學環境科學&#xff08;大氣化學&#xff09;博士在讀數據&#xff08;Excel格式&#xff09;&#xff1a;多站點污染物數據&#xff08;國&#xff0c;省&#xff0c;市控點&#xff09;&#xff0c;站點經緯度信息繪…

數字校驗

1 function validNumber(fieldname,fielddesc){2 var value $.trim($("#key_"fieldname).val());3 var num /^([0-9.])$/;4 5 var flag num.test(value);6 if(!flag) {7 alert("【"fielddesc"】只能輸入數字");8 …

JavaScript覆蓋率統計實現

主要需求 1、 支持browser & nodejs 由于javascript既能夠在瀏覽器環境執行&#xff0c;也能夠在nodejs環境執行&#xff0c;因此須要能夠統計兩種環境下單元測試的覆蓋率情況。 2、 透明、無縫 用戶寫單元測試用例的時候&#xff0c;不須要為了支持覆蓋率統計多寫代碼&…

leetcode 328. 奇偶鏈表(雙指針)

給定一個單鏈表&#xff0c;把所有的奇數節點和偶數節點分別排在一起。請注意&#xff0c;這里的奇數節點和偶數節點指的是節點編號的奇偶性&#xff0c;而不是節點的值的奇偶性。 請嘗試使用原地算法完成。你的算法的空間復雜度應為 O(1)&#xff0c;時間復雜度應為 O(nodes)…

NSLog打印當前文件,當前函數,當前行數

NSLog(”%s, %s, %d”, __FILE__, __FUNCTION__, __LINE__); 轉載于:https://www.cnblogs.com/shenfei2031/archive/2011/08/06/2129636.html

單元格內容分列多行_姓名太多,放在一列打印時浪費紙張,可以分成多行多列打印...

在日常工作中&#xff0c;往往會碰到這種情況(如下圖)&#xff1a;只有一列數據&#xff0c;而且比較多&#xff0c;如果打印起來就浪費紙張&#xff0c;然后復制、粘貼把表格變成幾列&#xff0c;方便打印。今天小編和大家分享不用復制、粘貼&#xff0c;就能快速完成一列分成…

caesar加密_如何編寫Caesar密碼:基本加密簡介

caesar加密by Brendan Massey由布倫丹梅西(Brendan Massey) The Caesar Cipher is a famous implementation of early day encryption. It would take a sentence and reorganize it based on a key that is enacted upon the alphabet. Take, for example, a key of 3 and th…

Java中接口、抽象類與內部類學習

2019獨角獸企業重金招聘Python工程師標準>>> Java中接口、抽象類與內部類學習 接口與內部類為我們提供了一種將接口與實現分離的更加結構化的方法。 抽象類和抽象方法 抽象方法&#xff1a;僅有聲明而沒有方法體。 抽象類&#xff1a;包含一個或多個抽象方法的類&am…

leetcode 402. 移掉K位數字(貪心算法)

給定一個以字符串表示的非負整數 num&#xff0c;移除這個數中的 k 位數字&#xff0c;使得剩下的數字最小。 注意: num 的長度小于 10002 且 ≥ k。 num 不會包含任何前導零。 示例 1 : 輸入: num “1432219”, k 3 輸出: “1219” 解釋: 移除掉三個數字 4, 3, 和 2 形成…

javascript 自定義Map

遷移時間&#xff1a;2017年5月25日08:24:19 Author:Marydon 三、自定義Map數據格式 需特別注意的是&#xff1a; js中沒有像java中的Map數據格式&#xff0c;js自帶的map()方法用于&#xff1a;返回一個由原數組中的每個元素調用一個指定方法后的返回值組成的新數組。 map()使…

gif分解合成_如何通過分解和合成使復雜的問題更容易

gif分解合成Discover Functional JavaScript was named one of the best new Functional Programming books by BookAuthority!“發現功能JavaScript”被BookAuthority評為最佳新功能編程書籍之一 &#xff01; Our natural way of dealing with complexity is to break it in…

vs2005 新建項目一片空白

最近在研究 workflow fundation ,但是在安裝了他的extensions之后&#xff0c;發現VS2005 新建項目一片空白&#xff0c;除開workflow其他的項目模板全部丟失&#xff0c;新建項目對話框中空空如也。查閱資料后發現&#xff0c;可以通過 命令 devenv.exe /InstallVSTemplates 來…