C++實現(xiàn)二叉樹非遞歸遍歷方法實例總結(jié)
更新時間:2014年08月27日 11:27:05 投稿:shichen2014
這篇文章主要介紹了C++實現(xiàn)二叉樹非遞歸遍歷方法實例總結(jié),是算法設計中比較經(jīng)典的一個遍歷算法,需要的朋友可以參考下
一般來說,二叉樹的遍歷是C++程序員在面試中經(jīng)??疾斓?,其實前中后三種順序的遍歷都大同小異,自己模擬兩個棧用筆畫畫是不難寫出代碼的?,F(xiàn)舉一個非遞歸遍歷的方法如下,供大家參考。
具體代碼如下:
class Solution { public: vector<int> preorderTraversal(TreeNode *root) { vector<int> out; stack<TreeNode*> s; s.push(root); while(!s.empty() && root){ TreeNode *node = s.top(); out.push_back(node->val); s.pop(); if(node->right) s.push(node->right); if(node->left) s.push(node->left); } return out; } vector<int> inorderTraversal(TreeNode *root) { stack<TreeNode *> s; vector<int> out; TreeNode *node = root; bool done = false; while(!done){ if(node){ s.push(node); node = node->left; }else { if(s.empty()) done = true; else{ node = s.top(); s.pop(); out.push_back(node->val); node = node->right; } } } return out; } vector<int> postorderTraversal(TreeNode *root) { vector<int> out; stack<TreeNode*> s; TreeNode* node = root; s.push(node); while(!s.empty()&&node){ node = s.top(); out.push_back(node->val); s.pop(); if(node->left) s.push(node->left); if(node->right)s.push(node->right); } reverse(out.begin(),out.end()); return out; } };
希望本文所述對大家的C++算法學習有所幫助。
相關(guān)文章
C語言排序算法之冒泡排序?qū)崿F(xiàn)方法【改進版】
這篇文章主要介紹了C語言排序算法之冒泡排序?qū)崿F(xiàn)方法,結(jié)合具體實例形式分析了C語言實現(xiàn)的基本冒泡排序?qū)崿F(xiàn)方法及增設flag標志位的改進型算法,需要的朋友可以參考下2017-09-09C語言經(jīng)典算法例題求100-999之間的“水仙花數(shù)”
本文的主要內(nèi)容,設計一個程序,找出100-999之間的“水仙花數(shù)”,需要的朋友可以參考下2015-07-07