給定一個二叉樹,返回它的 后序?遍歷。
示例:
輸入: [1,null,2,3] ?
? ?1
? ? \
? ? ?2
? ? /
? ?3?輸出: [3,2,1]
進階:?遞歸算法很簡單,你可以通過迭代算法完成嗎?來源:力扣(LeetCode)
鏈接:https://leetcode-cn.com/problems/binary-tree-postorder-traversal
著作權歸領扣網絡所有。商業轉載請聯系官方授權,非商業轉載請注明出處。
解法一:
class Solution {
public:vector<int> postorderTraversal(TreeNode* root) {if (!root) return {};vector<int> res;stack<TreeNode*> s{{root}};TreeNode *head = root;while (!s.empty()) {TreeNode *t = s.top();if ((!t->left && !t->right) || t->left == head || t->right == head) {res.push_back(t->val);s.pop();head = t;} else {if (t->right) s.push(t->right);if (t->left) s.push(t->left);}}return res;}
};
?