非遞歸遍歷二叉樹利用棧的先進先出特點完成實現(xiàn)
創(chuàng)新互聯(lián)客戶idc服務(wù)中心,提供聯(lián)通服務(wù)器托管、成都服務(wù)器、成都主機托管、成都雙線服務(wù)器等業(yè)務(wù)的一站式服務(wù)。通過各地的服務(wù)中心,我們向成都用戶提供優(yōu)質(zhì)廉價的產(chǎn)品以及開放、透明、穩(wěn)定、高性價比的服務(wù),資深網(wǎng)絡(luò)工程師在機房提供7*24小時標準級技術(shù)保障。
前序比較好理解先壓根入棧,在while里面訪問根,根出棧,再壓入右子樹,左子樹,這樣的遍歷二叉樹就是前序遍歷了。
void PrevOrdr_NonR()
{
stack
s.push(_root);
while(!s.empty())
{
BinaryTreeNode
s.pop();
cout<
if(top->_right)
s.push(top->_right);
if(top->_left)
s.push(top->_left);
}
cout< } 中序的遍歷順序是左子樹、根節(jié)點、右子樹。 void InOreder_NonR() { stack BinaryTreeNode while(cur || !s.empty()) { while(cur)//把左路徑的節(jié)點全部壓入棧 { s.push(cur); cur = cur->_left; } if(!s.empty()) { BinaryTreeNode s.pop(); cout< cur = cur->_right;//把cur指向最后一個左節(jié)點的右節(jié)點 } } cout< } 后序遍歷是左子樹、右子樹、根節(jié)點。 void PostOrder_NonR() { stack BinaryTreeNode BinaryTreeNode while(cur || s.empty()) { while(cur)//左路徑的節(jié)點入棧 { s.push(cur); cur = cur->_left; } BinaryTreeNode if(top->_right == NULL || top->right == preVisited) //當子樹遍歷之后回退到上一個沒有遍歷的子樹 { cout< preVisited = tmp; s.pop(); } else { cur = cur->left;//把cur指向右子樹繼續(xù)尋找左節(jié)點 } } }
分享題目:二叉樹前序、中序和后序的非遞歸遍歷
本文鏈接:http://weahome.cn/article/gescpo.html