首页 > 其他分享 >二叉树的统一迭代法遍历

二叉树的统一迭代法遍历

时间:2022-08-20 20:23:25浏览次数:75  
标签:node 遍历 TreeNode nullptr st 二叉树 push 迭代法

中序遍历

中序遍历无法直接利用栈进行遍历,需要利用指针进行遍历,对栈中的节点进行操作。
对于中间节点,如果指针遍历到了,但没有进行处理,就再push()一个nullptr,作为标记,说明这个节点只是遍历过了,但是没有处理。事实上,每个待处理(放入vector)中的节点,其在栈中的上层元素都会是nullptr

#include <iostream>
#include <stack>
#include <vector>
using std::stack;
using std::vector;

struct TreeNode {
    int val;
    TreeNode *left;
    TreeNode *right;
    TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
};

class Solution {
  public:
    vector<int> inorderTraversal(TreeNode *root) {
        vector<int> result;
        stack<TreeNode *> st;
        if (root != nullptr)
            st.push(root);
        while (!st.empty()) {
            TreeNode *node = st.top();
			//对节点进行遍历
            if (node != nullptr) {
                st.pop(); // 将该节点弹出,避免重复操作,下面再将右中左节点添加到栈中
                if (node->right != nullptr)
                    st.push(node->right);
                st.push(node);
                st.push(nullptr);
                if (node->left != nullptr)
                    st.push(node->left);
            } else {//依次处理节点
                st.pop();
                node = st.top();
                st.pop();
                result.push_back(node->val);
            }
        }
        return result;
    }
};

前序遍历

相比中序遍历,只是需要调整遍历部分,即st.push()的顺序即可。

vector<int> preorderTraversal(TreeNode *root) {
    vector<int> result;
    stack<TreeNode *> st;
    if (root != nullptr)
        st.push(root);
    while (!st.empty()) {
        TreeNode *node = st.top();
        if (node != nullptr) {
            st.pop();
            if (node->right != nullptr)
                st.push(node->right);
            if (node->left != nullptr)
                ;
            st.push(node->left);
            st.push(node);
            st.push(nullptr);
        } else {
            st.pop();
            node = st.top();
            st.pop();
            result.push_back(node->val);
        }
    }
}

后序遍历

相比中序遍历也只是调整遍历顺序而已

vector<int> postorderTraversal(TreeNode *root) {
    vector<int> result;
    stack<TreeNode *> st;
    if (root != nullptr)
        st.push(root);
    while (!st.empty()) {
        TreeNode *node = st.top();
        if (node != nullptr) {
            st.pop();
            st.push(node);
            st.push(nullptr);
            if (node->right != nullptr)
                st.push(node->right);
            if (node->left != nullptr)
                st.push(node->left);
        } else {
            st.pop();
            node = st.top();
            st.pop();
            result.push_back(node->val);
        }
    }
}

标签:node,遍历,TreeNode,nullptr,st,二叉树,push,迭代法
From: https://www.cnblogs.com/zwyyy456/p/16608515.html

相关文章

  • 树结构遍历 (深度遍历/广度遍历)
     //深度遍历结果[1,2,21,22,23,3,31,32,33];//广度遍历结果[1,2,3,21,22,23,31,32,33];      ......
  • 二叉树 查找第k大的数
    改造方法需在节点N中记录以节点N为根的子树的节点数numOfNodes,根节点记录整颗树的节点数目,则若根节点的左子树的numOfNodes刚好为k-1,那这个根节点的值即为目标值。注意......
  • JQuery遍历
    JQuery遍历1.js的遍历方式for(初始化值;循环结束条件;步长)HTML代码<!DOCTYPEhtml><html><head><metacharset="UTF-8"><title></title><script......
  • 2022-8-20 每日一题-二叉树-递归
    654.最大二叉树难度中等499收藏分享切换为英文接收动态反馈给定一个不重复的整数数组 nums 。 最大二叉树 可以用下面的算法从 nums 递归地构建:创建一个......
  • JQuery_遍历for循环&each方法$全局each&forof讲解
    遍历js的遍历方式for(初始化值;循环结束条件;步长)JQuery遍历方式JQuery对象.each(callback)$.each(object,[callback])for..of;<!DOCTYPEhtml><html><hea......
  • JQuery遍历
    JQuery遍历1.js的遍历方式for(初始化值;循环结束条件;步长)2.JQuery的遍历方式1.JQuery对象.each(callback)2.$.each(object,[callback])3.for..of......
  • JQuery遍历
    遍历1、js的遍历方式for(初始值;循环结束条件;步长)<!DOCTYPEhtml><html><head><metacharset="UTF-8"><title></title><scriptsrc="../../js/......
  • 654. 最大二叉树
    654.最大二叉树给定一个不重复的整数数组 nums。 最大二叉树 可以用下面的算法从 nums递归地构建:创建一个根节点,其值为 nums中的最大值。递归地在最大值......
  • LeetCode/最大二叉树
    给定一个不重复的整数数组nums。最大二叉树可以用下面的算法从nums递归地构建:创建一个根节点,其值为nums中的最大值递归地在最大值左边的子数组前缀上构建......
  • 列表的循环遍历、列表嵌套、综合案例
    1.whilename_list=['aaa','bbb','ccc']i=0#len是访问数据个数whilei<len(name_list):#查看下标数据print(name_list[i])i+=1#结果:......