设为首页 加入收藏

TOP

Binary Tree Level Order Traversal II
2015-07-20 17:32:55 来源: 作者: 【 】 浏览:3
Tags:Binary Tree Level Order Traversal

Given a binary tree, return the bottom-up level order traversal of its nodes' values. (ie, from left to right, level by level from leaf to root).

For example:
Given binary tree {3,9,20,#,#,15,7},

    3
   / \
  9  20
    /  \
   15   7

return its bottom-up level order traversal as:

[
  [15,7],
  [9,20],
  [3]
]
点击打开原题链接

跟从上往下层次遍历一样,最后把结果倒置一下就可以了~~


struct node
 {
	 TreeNode* tn;
	 int level;
 };
	
	class Solution 
	{
	public:
		vector
  
    > levelOrderBottom(TreeNode *root) 
		{
			vector
   
     > vvi; vector
    
      vi; deque
     
       di; node nd; int level = 0; if (root == NULL) { return vvi; } nd.level = 0; nd.tn = root; di.push_back(nd); node left,right; while (!di.empty()) { nd = di.front(); if (nd.tn->left != NULL) { left.tn = nd.tn->left; left.level = nd.level+1; di.push_back(left); } if (nd.tn->right != NULL) { right.tn = nd.tn->right; right.level = nd.level + 1; di.push_back(right); } // if (vi.empty()) // { // vi.push_back(nd.tn->val); // level++; // di.pop_front(); // } // else // { nd = di.front(); if (nd.level == level) { vi.push_back(nd.tn->val); di.pop_front(); } else { vvi.push_back(vi); vi.clear(); vi.push_back(nd.tn->val); level++; di.pop_front(); } // } } vvi.push_back(vi); return vector
      
        >(vvi.rbegin(),vvi.rend()); } };
      
     
    
   
  


】【打印繁体】【投稿】【收藏】 【推荐】【举报】【评论】 【关闭】 【返回顶部
分享到: 
上一篇HDOJ 4417 Super Mario 下一篇Ural 1586 Threeprime Numbers(D..

评论

帐  号: 密码: (新用户注册)
验 证 码:
表  情:
内  容:

·Bash 脚本教程——Li (2025-12-26 07:53:35)
·实战篇!Linux shell (2025-12-26 07:53:32)
·整理了250个shell脚 (2025-12-26 07:53:29)
·HyperText Transfer (2025-12-26 07:20:48)
·半小时搞懂 HTTP、HT (2025-12-26 07:20:42)