设为首页 加入收藏

TOP

Binary Tree Level Order Traversal II
2015-07-20 17:32:55 来源: 作者: 【 】 浏览:2
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..

评论

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

·JAVA现在的就业环境 (2025-12-26 01:19:24)
·最好的java反编译工 (2025-12-26 01:19:21)
·预测一下2025年Java (2025-12-26 01:19:19)
·Libevent C++ 高并发 (2025-12-26 00:49:30)
·C++ dll 设计接口时 (2025-12-26 00:49:28)