LeetCode 257. Binary Tree Paths

public List<String> binaryTreePaths(TreeNode root) {
		List<String> result = new ArrayList<String>();
		order(root, result, new StringBuffer());
		return result;
	}
	
	public void order(TreeNode node, List<String> result, StringBuffer sb) {
		if(node == null) {
			return;
		}
		
		sb.append(node.val);
		if(node.left == null && node.right == null) {
			result.add(sb.toString());
			return;
		}
		sb.append("->");
		
		//注意:这里要new,否则左右子树的路径会叠加,而不是选其中一条路径
		order(node.left, result, new StringBuffer(sb));
		order(node.right, result, new StringBuffer(sb));
	}

这题的关键点:

在递归的时候要new一个StringBuffer对象,因为StringBuffer不是基本数据类型,调用方法传的是地址,如果两个order() 都操作同一个StringBuffer对象,那么左右子树的路径将会叠加,而不是只选其一。所以new一个StringBuffer对象的作用是让当前状态下的StringBuffer分别走两条不同的路径。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值