二叉树的中序遍历-力扣

  • 二叉树的中序遍历,指首先遍历左节点,然后遍历中间节点,最后遍历右节点,按照这个顺序进行递归即可。
/**
 * 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:
    void traversal(TreeNode* cur, vector<int>& vec){
        if(cur == nullptr){
            return;
        }
        traversal(cur->left, vec);
        vec.push_back(cur->val);
        traversal(cur->right, vec);
    }
    vector<int> inorderTraversal(TreeNode* root) {
        vector<int> result;
        traversal(root, result);
        return result;
    }
};
  • 二叉树的中序遍历的迭代方法,和前后序存在一点不同,原因在于处理节点的顺序,与入栈节点的顺序不同,中序遍历需要首先将树的最左侧节点入栈,然后再处理中间节点,然后处理中间节点的右节点的左节点。
/**
 * 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> result;
        stack<TreeNode*> st;
        TreeNode* cur = root;
        while(cur != nullptr || !st.empty()){
            if(cur != nullptr){
                st.push(cur);
                cur = cur->left;
            } else {
                cur = st.top();
                st.pop();
                result.push_back(cur->val);
                cur = cur->right;
            }
        }
        return result;
    }
};

相关推荐

  1. -

    2024-06-06 16:28:05       11 阅读
  2. -

    2024-06-06 16:28:05       9 阅读
  3. -

    2024-06-06 16:28:05       8 阅读
  4. 94.

    2024-06-06 16:28:05       31 阅读
  5. 94-

    2024-06-06 16:28:05       31 阅读
  6. 94.

    2024-06-06 16:28:05       19 阅读
  7. 2024.2.10每日一题——

    2024-06-06 16:28:05       19 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-06-06 16:28:05       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-06-06 16:28:05       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-06-06 16:28:05       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-06-06 16:28:05       18 阅读

热门阅读

  1. 二叉树的前序遍历-力扣

    2024-06-06 16:28:05       9 阅读
  2. mysql数据备份和还原知识点

    2024-06-06 16:28:05       7 阅读
  3. WPF 按键图标转动效果示例

    2024-06-06 16:28:05       7 阅读
  4. 【归档】git使用

    2024-06-06 16:28:05       6 阅读
  5. 【源码】SpringBoot事务注册原理

    2024-06-06 16:28:05       8 阅读