zoukankan      html  css  js  c++  java
  • 94. Binary Tree Inorder Traversal

    • 中序遍历二叉树(非递归)
      使用一个辅助栈
      题目来源

    • C++实现

    /**
     * Definition for a binary tree node.
     * struct TreeNode {
     *     int val;
     *     TreeNode *left;
     *     TreeNode *right;
     *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
     * };
     */
    class Solution 
    {
    public:
        vector<int> inorderTraversal(TreeNode* root)
        {
            stack<TreeNode*> data;
    		vector<int> treedata;
    		
    		while(!data.empty() || root != NULL)
    		{
    			if(root != NULL)
    			{
    				data.push(root);
    				root = root->left;
    			}
    			else
    			{
    				root = data.top();
                    treedata.push_back(root->val);
    				data.pop();
    				root = root->right;
    			}
    		}
    		
    		return treedata;
        }
    };
    
  • 相关阅读:
    iou与giou对比
    Linux学习第一天 vim
    奖励加分申请
    人月神话阅读笔记3
    5.27
    5.26
    5.25
    5.23
    5.22
    5.21
  • 原文地址:https://www.cnblogs.com/Manual-Linux/p/12074696.html
Copyright © 2011-2022 走看看