LeetCode107 Binary Tree Level Order Traversal II

题目:

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]
]

题解:

这题这102题(我上一篇博客)几乎是一模一样的,所有我只改动了一行代码, result.add(tempReslut)改为了result.add(0,tempReslut);

代码:

 public static List<List<Integer>> levelOrderBottom(TreeNode root) {
		 
		 List<List<Integer>> result=new ArrayList<List<Integer>>();//返回的最终结果
		   Queue<TreeNode> treeNodes2=new LinkedList<>();//用来存放每一层的节点
		   
		   //处理第一个节点(root)
		   if(root==null)
			   return result;
		   else {
			   List<Integer> temp=new ArrayList<>();//存放暂时的结果
			   temp.add(root.val);
			   treeNodes2.offer(root);
			   result.add(temp);
			  
		   }
		 
		   while(!treeNodes2.isEmpty())
		   {
			  int i=treeNodes2.size();
			  List<Integer> tempReslut=new ArrayList<>();//存放暂时的结果
			  while(i>0)//遍历这一层的所有节点
			  {
				  
				  TreeNode tNode=treeNodes2.poll();
				  if(tNode.left!=null)
				  {
					  tempReslut.add(tNode.left.val);
					  treeNodes2.offer(tNode.left);
				  }
				  if(tNode.right!=null)
				  {
					  tempReslut.add(tNode.right.val);
					  treeNodes2.offer(tNode.right);
				  }
				  i--;
			  }
			  if(!tempReslut.isEmpty()) result.add(0,tempReslut);  
			 
		   }
		   
		   return result;
	        
	    }


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值