码迷,mamicode.com
首页 > 其他好文 > 详细

Leetcode 之Binary Tree Inorder Traversal(43)

时间:2016-05-28 17:12:05      阅读:116      评论:0      收藏:0      [点我收藏+]

标签:

技术分享

树的中序遍历。先不断压入左结点至末尾,再访问,再压入右结点。注意和先序遍历的比较

技术分享
vector<int> inorderTraversal(TreeNode *root)
      {
          vector<int> result;
          stack<TreeNode *>s;
          TreeNode *p = root;
          while (!s.empty() || p != nullptr)
          {
              if (p != nullptr)
              {
                  //将当前结点和其左结点不断入栈
                  s.push(p);
                  p = p->left;
              }
              else
              {
                  //访问到了左结点末尾
                  //访问该结点并弹出
                  p = s.top();
                  result.push_back(p->val);
                  s.pop();
                  //将方向转为其右结点
                  p = p->right;
              }
          }
          return result;
      }
View Code

 

Leetcode 之Binary Tree Inorder Traversal(43)

标签:

原文地址:http://www.cnblogs.com/573177885qq/p/5537525.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!