二叉树的中序遍历

二叉树的中序遍历

法一:递归,最简单的方法

直接上代码:注意 递归终止条件为碰到空结点。

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
    vector<int>ans;
    void zxbl(TreeNode* node)
    {
        if(!node) return;//注意递归都要有终止条件,这里递归终止的条件为碰到空节点。
        zxbl(node->left);
        ans.push_back(node->val);//加入当前结点
        zxbl(node->right);
    }
public:
    vector<int> inorderTraversal(TreeNode* root) {
        zxbl(root);
        return ans;
    }
};

法二:迭代(要掌握!)

递归函数我们也可以用迭代的方式实现,两种方式是等价的,区别在于递归的时候隐式地维护了一个栈,而我们在迭代的时候需要显式地将这个栈模拟出来,其他都相同,具体实现可以看下面的代码。

关键思路就是这个栈(先入后出)! 首先对于每个结点 就先放入栈中,然后看它有没有左孩子,有左孩子就将左孩子继续放入栈中,没有左孩子就把当前结点输出,再看它有没有右孩子,有的话就放入栈中,继续上述操作,每次都处理当前结点。

代码其实之前有写过类似的。

注意:栈和队列是push,vector是push_back

代码:

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    vector<int> inorderTraversal(TreeNode* root) {
        vector<int> ans;
        stack<TreeNode *> st;//栈,存每一个结点,是指针类型的
        while(root||!st.empty())//栈不空
        {
            while(root)
            {
                st.push(root);
                root=root->left;
            }
            auto t=st.top();
            st.pop();
            ans.push_back(t->val);
            root=t->right;

        }
        return ans;
    }
};

这个迭代的代码需要好好理解,为什么这么写,好好思考琢磨。

相关推荐
zth4130216 分钟前
SegmentSplay‘s Super STL(v2.2)
开发语言·c++·算法
数据知道13 分钟前
claw-code 源码详细分析:Bootstrap Graph——启动阶段图式化之后,排障与扩展为什么会变简单?
前端·算法·ai·bootstrap·claude code·claw code
Kel16 分钟前
从Prompt到Response:大模型推理端到端核心链路深度拆解
人工智能·算法·架构
Felven16 分钟前
D. Matryoshkas
算法
17(无规则自律)29 分钟前
DFS连通域统计:岛屿数量问题及其变形
c++·算法·深度优先
笨笨饿1 小时前
34_数据结构_栈
c语言·开发语言·数据结构·人工智能·嵌入式硬件·算法
im_AMBER1 小时前
Leetcode 152 被围绕的区域 | 岛屿数量
数据结构·算法·leetcode·深度优先·广度优先·图搜索算法
吕司1 小时前
LeetCode Hot Code——最大子数组和
数据结构·算法·leetcode
海清河晏1111 小时前
数据结构 | 单链表
数据结构·unity·dreamweaver
XiYang-DING1 小时前
【LeetCode】144. 二叉树的前序遍历
算法·leetcode·职场和发展