题目1368:二叉树中和为某一值的路径

题目描述:

输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径。路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径。

输入:

每个测试案例包括n+1行:

第一行为2个整数n,k(1<=n<=10000),n表示结点的个数,k表示要求的路径和,结点编号从1到n。

接下来有n行。这n行中每行为3个整数vi,leftnode,rightnode,vi表示第i个结点的值,leftnode表示第i个结点的左孩子结点编号,rightnode表示第i个结点的右孩子结点编号,若无结点值为-1。编号为1的结点为根结点。

代码:

 1 #include<stdio.h>
 2 #include<cstring>
 3 #include<stack>
 4 using namespace std;
 5 const int MAXN = 10500;
 6     int n, k;
 7     int tmp1, tmp2;
 8     int node[MAXN];
 9     int mem[MAXN];
10     int lft[MAXN];
11     int rgt[MAXN];
12     stack<int> st;
13 void Print(int num, int sum){
14     if(num==-1||sum+node[num]>k)
15         return;
16     else{
17         int i=num;
18         sum+=node[i];
19         if(sum==k&&lft[num]==-1&&rgt[num]==-1){
20             printf("A path is found:");
21             while(i){
22                 st.push(i);
23                 i=mem[i];
24             }
25             while(!st.empty()){
26                 printf(" %d",st.top());
27                 st.pop();
28             }
29             puts("");
30         }
31         Print(lft[num],sum);
32         Print(rgt[num],sum);
33     }
34 }
35 int main(){
36     while(~scanf("%d%d",&n,&k)){
37         memset(node,0,sizeof(node));
38         memset(mem,0,sizeof(mem));
39         //记录父节点
40         memset(lft,0,sizeof(mem));
41         //记录左子
42         memset(rgt,0,sizeof(mem));
43         //记录右子
44         for(int i=1;i<=n;i++){
45             scanf("%d%d%d",&node[i],&tmp1,&tmp2);
46             if(tmp1>tmp2)
47                 swap(tmp1,tmp2);
48             if(tmp1>0)
49                 mem[tmp1]=i;
50             if(tmp2>0)
51                 mem[tmp2]=i;
52             lft[i]=tmp1;
53             rgt[i]=tmp2;
54         }
55         printf("result:\n");
56         int sum=0;
57         Print(1,sum);
58     }
59 }

一开始想当然了,输入的时候第i行代表第i个结点的相关信息,但是也有可能是第4个结点,子结点是7和8,然后第8个结点的子结点是5,这样就不能在预处理的时候全部得到结点的最终值,而只能在深搜的时候获取相关信息。

时间: 2024-10-11 06:29:31

题目1368:二叉树中和为某一值的路径的相关文章

二叉树中和为某一值的路径-剑指Offer

二叉树中和为某一值的路径 题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 思路 用栈来存储二叉树的路径,遍历到叶子结点就判断是否总和为target,是的话打印,若不是叶子结点,那继续遍历左右子树 注意:打印完后返回父结点时要弹出栈顶的叶子结点,并且总和减去该值 注意:打印路径时要遍历栈 代码 import java.util.ArrayList; import java.util.Stack;

23.二叉树中和为某一值的路径

二叉树中和为某一值的路径 参与人数:2929时间限制:1秒空间限制:32768K 算法知识视频讲解 题目描述 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 牛客网不给测试用例让我感到很迷惑啊..再次提醒自己,vector是否为空用vector.empty()判断! // 24.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <v

打印二叉树中和为某一值的路径

输入一个二叉树,查找该树的所有路径(从根结点到叶结点的通路),并返回和(路径上所有结点值的和)为某一指定值的路径. 1 /////////////二叉树中和为某一值的路径///////////////////// 2 void FindPath(BinaryTreeNode* pRoot ,int expectedSum ,vector<int>& path ,int currentSum) 3 { 4 if (pRoot == NULL) 5 { 6 return; 7 } 8 cu

LeetCode | 面试题34. 二叉树中和为某一值的路径【剑指Offer】【Python】

LeetCode 面试题34. 二叉树中和为某一值的路径[剑指Offer][Medium][Python][回溯] 问题 力扣 输入一棵二叉树和一个整数,打印出二叉树中节点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶节点所经过的节点形成一条路径. 示例: 给定如下二叉树,以及目标和 sum = 22, 5 / 4 8 / / 11 13 4 / \ / 7 2 5 1 返回: [ [5,4,11,2], [5,8,4,5] ] 提示: 节点总数 <= 10000 注意:本题与主站 1

九度oj 题目1368:二叉树中和为某一值的路径

题目描述: 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 输入: 每个测试案例包括n+1行: 第一行为2个整数n,k(1<=n<=10000),n表示结点的个数,k表示要求的路径和,结点编号从1到n. 接下来有n行.这n行中每行为3个整数vi,leftnode,rightnode,vi表示第i个结点的值,leftnode表示第i个结点的左孩子结点编号,rightnode表示第i个结点的右孩子结点编号

九度 题目1368:二叉树中和为某一值的路径

和之前的一篇分析的结果一样,当需要枚举可能性的时候,使用DFS的方法进行搜索 然后采用回溯的方法进行节点的输出. 本题值得注意的两点是 1:必须是叶子节点,中间节点不可以 2:因为是有序的输出,所以,把节点交换一下,使得左子树小于又子树 #include <stdio.h> #include <vector> using namespace std; struct Node { int value,lchild,rchild; }nodes[10010]; vector<in

25 - 二叉树中和为某一值的路径

题目描述:http://ac.jobdu.com/problem.php?pid=1368 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 解析: 需要找出从根节点到叶节点的路径和等于target,可以想到用深度搜索(前序遍历)方式,当访问某节点时,将该节点添加到路径上,如果该节点是叶节点且恰好等于target,则找到了路径:反之,继续向它的左右子树遍历.当含有该节点的路径不能满足条件时,在返回到父节点

剑指OFFER之二叉树中和为某一值的路径

题目描述: 输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.路径定义为从树的根结点开始往下一直到叶结点所经过的结点形成一条路径. 输入: 每个测试案例包括n+1行: 第一行为2个整数n,k(1<=n<=10000),n表示结点的个数,k表示要求的路径和,结点编号从1到n. 接下来有n行.这n行中每行为3个整数vi,leftnode,rightnode,vi表示第i个结点的值,leftnode表示第i个结点的左孩子结点编号,rightnode表示第i个结点的右孩子结点编号

剑指Offer面试题25(Java版):二叉树中和为某一值的路径

题目:输入一颗二叉树和一个整数,打印出二叉树中结点值的和为输入整数的所有路径.从树的根节点开始往下一直到叶结点所经过的所有的结点形成一条路径. 如下图,输入二叉树和整数22,则打印出两条路径,第一条路径包含结点10,12,第二条路径包含的结点为10,5,7. 一般的数据结构和算法的教材都没有介绍树的路径,因此对大多数应聘者而言,这是一个新概念,也就很难一下子想出完整的解题思路.这个时候我们可以试着从一两个具体的例子入手,找到规律. 以图中的二叉树为例分析,由于路径是从根节点出发到叶结点,也就是说