C++非遞歸隊(duì)列實(shí)現(xiàn)二叉樹的廣度優(yōu)先遍歷
更新時(shí)間:2015年07月11日 09:13:56 作者:優(yōu)雅先生
這篇文章主要介紹了C++非遞歸隊(duì)列實(shí)現(xiàn)二叉樹的廣度優(yōu)先遍歷,實(shí)例分析了遍歷二叉樹相關(guān)算法技巧,并附帶了兩個(gè)相關(guān)算法實(shí)例,需要的朋友可以參考下
本文實(shí)例講述了C++非遞歸隊(duì)列實(shí)現(xiàn)二叉樹的廣度優(yōu)先遍歷。分享給大家供大家參考。具體如下:
廣度優(yōu)先非遞歸二叉樹遍歷(或者說層次遍歷):
void widthFirstTraverse(TNode* root) {
queue<TNode*> q; // 隊(duì)列
q.enqueue(root);
TNode* p;
while(q.hasElement()) {
p = q.dequeue(); // 隊(duì)首元素出隊(duì)列
visit(p); // 訪問p結(jié)點(diǎn)
if(p->left)
q.enqueue(p->left);
if(p->right)
q.enqueue(p->right);
}
}
附帶兩個(gè)相關(guān)示例:
1. 遞歸先序遍歷二叉樹
void preTraverse(TNode* root) {
if(!root)
return;
visit(root);
preTraverse(root->left);
preTraverse(root->Right);
}
2. 非遞歸先序遍歷二叉樹
void preTraverseNonRecursive(TNode* root) {
stack<TNode> stack; // 棧
stack.push(root);
TNode* p;
while(!stack.isEmpty()) { // 棧非空
p = stack.pop();
visit(p);
if(p->pRight)
s.push(p->pRight);
if(p->pLeft)
s.push(p->pLeft);
}
}
希望本文所述對(duì)大家的C++程序設(shè)計(jì)有所幫助。
相關(guān)文章
c++ 預(yù)處理之正整型實(shí)現(xiàn)方法
這篇文章主要介紹了c++ 預(yù)處理之正整型實(shí)現(xiàn)方法,需要的朋友可以參考下2017-07-07
C語言中邏輯運(yùn)算符與條件運(yùn)算符的學(xué)習(xí)教程
這篇文章主要介紹了C語言中邏輯運(yùn)算符與條件運(yùn)算符的學(xué)習(xí)教程,條件運(yùn)算符問號(hào)即三目運(yùn)算符使用起來十分方便,需要的朋友可以參考下2016-04-04
C++實(shí)現(xiàn)圖片轉(zhuǎn)base64的示例代碼
Base64就是一種 基于64個(gè)可打印字符來表示二進(jìn)制數(shù)據(jù)的表示方法,本文主要為大家詳細(xì)介紹了如何使用C++實(shí)現(xiàn)圖片轉(zhuǎn)base64,需要的可以參考下2024-04-04
Qt實(shí)現(xiàn)帶字?jǐn)?shù)限制的文字輸入框
這篇文章介紹了Qt實(shí)現(xiàn)帶字?jǐn)?shù)限制文字輸入框的方法,對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04

