網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
? ? ?在本算法中先利用先序遍歷創(chuàng)建了樹(shù),利用了遞歸的算法使得算法簡(jiǎn)單,操作容易,本來(lái)無(wú)printf("%c的左/右子樹(shù):", ch);的語(yǔ)句,但由于計(jì)算機(jī)需要輸入空格字符來(lái)判斷左右子樹(shù),為了減少人為輸入的失誤,特地加入這條語(yǔ)句,以此保證準(zhǔn)確率。
#include<stdio.h> #include<stdlib.h> #define OK 1 #define ERROR 0 #define OVERFLOW 3 typedef int Status; typedef int Boolean; typedef char TElemType; typedef struct BiTNode{ TElemType data; struct BiTNode *lchild, *rchild; }BiTNode, *BiTree; //創(chuàng)建二叉樹(shù)函數(shù) Status CreateBiTree(BiTree &T){ TElemType ch; scanf("%c", &ch); getchar(); if(ch == ' '){ T = NULL;} else { if( !(T=(BiTree)malloc(sizeof(BiTNode))))(exit(OVERFLOW)); T->data = ch; printf("%c的左子樹(shù):", ch); CreateBiTree(T->lchild); printf("%c的右子樹(shù):", ch); CreateBiTree(T->rchild); } return OK; } //先序遍歷函數(shù) Status PreOrderTraverse(BiTree T, Status (* Visit)(TElemType e)){ if(T){ if(Visit(T->data)){ if(PreOrderTraverse(T->lchild, Visit)){ if(PreOrderTraverse(T->rchild, Visit)){ return OK; } } } return ERROR; } else {return OK;} } //中序遍歷函數(shù) Status InOrderTraverse(BiTree T, Status (* Visit)(TElemType e)){ if(T){ if(PreOrderTraverse(T->lchild, Visit) ){ if(Visit(T->data)){ if(PreOrderTraverse(T->rchild, Visit) ){ return OK; } } } return ERROR; } else { return OK; } } //后序遍歷函數(shù) Status PosOrderTraverse(BiTree T, Status (* Visit)(TElemType e)){ if(T){ if(PreOrderTraverse(T->lchild, Visit) ){ if(PreOrderTraverse(T->rchild, Visit) ){ if(Visit(T->data)){return OK; } } } return ERROR;} else {return OK; } } //輸出二叉樹(shù)函數(shù) Status PrintElement(TElemType e){ printf("%c",e); return OK; } //主函數(shù) int main(){ BiTree T; printf("輸入根結(jié)點(diǎn):"); CreateBiTree(T); printf("先序遍歷:\n"); PreOrderTraverse(T, PrintElement); printf("\n"); printf("中序遍歷:\n"); InOrderTraverse(T, PrintElement); printf("\n"); printf("后序遍歷:\n"); PosOrderTraverse(T, PrintElement); return 0; }
? ? ? ?遍歷操作有四種,其不同在于對(duì)根結(jié)點(diǎn)的訪問(wèn)順序不同。在先序遍歷中,首先訪問(wèn)根結(jié)點(diǎn),然后遞歸地做左子樹(shù)的先序遍歷,然后是右子樹(shù)的遞歸先序遍歷。 在中序遍歷中,遞歸地對(duì)左子樹(shù)進(jìn)行中序遍歷,訪問(wèn)根結(jié)點(diǎn),最后遞歸中序遍歷右子樹(shù)。在后序遍歷中,遞歸地對(duì)左子樹(shù)和右子樹(shù)進(jìn)行后序遍歷,然后訪問(wèn)根結(jié)點(diǎn)。先序,中序,后序遍歷就是對(duì)于根節(jié)點(diǎn)的訪問(wèn)順序。
? ? ? ?但無(wú)論哪種遍歷方式,遞歸的方法是最簡(jiǎn)便,最直接,最簡(jiǎn)單的算法。
? ? ? 運(yùn)行截圖:
原文鏈接:https://blog.csdn.net/Yuto_1/article/details/122329549
相關(guān)推薦
- 2022-07-13 Docker資源限制Cgroup
- 2022-04-22 Spring AOP 在注解上使用SPEL表達(dá)式注入對(duì)象
- 2022-07-06 C語(yǔ)言實(shí)現(xiàn)可增容動(dòng)態(tài)通訊錄詳細(xì)過(guò)程_C 語(yǔ)言
- 2022-11-05 Rust使用libloader調(diào)用動(dòng)態(tài)鏈接庫(kù)_Rust語(yǔ)言
- 2022-09-09 Go語(yǔ)言中defer語(yǔ)句的用法_Golang
- 2022-12-27 C語(yǔ)言中strcpy()函數(shù)的具體實(shí)現(xiàn)及注意事項(xiàng)_C 語(yǔ)言
- 2022-09-12 .Net6集成IdentityServer4?+AspNetCore?Identity讀取數(shù)據(jù)表用戶
- 2022-12-28 C++數(shù)據(jù)結(jié)構(gòu)之哈希算法詳解_C 語(yǔ)言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支