代码拉取完成,页面将自动刷新
同步操作将从 star/offer100 强制同步,此操作会覆盖自 Fork 仓库以来所做的任何修改,且无法恢复!!!
确定后同步将在后台操作,完成时将刷新页面,请耐心等待。
<?php
/**
* 二叉树中和为某一值的路径
* 输入一颗二叉树的跟节点和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。
* 思路:先序遍历
*/
class TreeNode{
public $val;
public $left = NULL;
public $right = NULL;
public function __construct($val){
$this->val = $val;
}
}
function FindPath($root, $expectNumber)
{
if ($root == null) {
return '';
}
$path = [];
$curSum = 0;
FindPathDetail($root, $expectNumber, $path, $curSum);
}
function FindPathDetail($root, $expectNumber, $path, $curSum)
{
if ($root != null) {
array_push($path, $root->val);
$curSum += $root->val;
if ($expectNumber == $curSum) {
printPath($path);
}
FindPathDetail($root->left, $expectNumber, $path, $curSum);
FindPathDetail($root->right, $expectNumber, $path, $curSum);
// 回到父节点之前,需要删除当前节点
$curSum -= $root->val;
array_pop($path);
}
}
function printPath($path)
{
foreach ($path as $key => $value) {
echo $value.' ';
}
echo '<br />';
}
$node = new TreeNode(10);
$node->left = new TreeNode(5);
$node->right = new TreeNode(12);
$node->left->left = new TreeNode(4);
$node->left->right = new TreeNode(7);
$num = 22;
FindPath($node, $num);
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。