百度面试题目:
输入一个整数和一棵二元树。从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。打印出和与输入整数相等的所有路径。
例如输入整数 22 ,如下图二元树:
10
/ \
5 12
/ \
4 7
则打印出两条路径:10, 12和10, 5, 7。
分析:看到该题目的第一反应是:递归+回溯。首先当然要保存搜索的路径,并记录当前路径上所有元素的和。如果累积和与当前节点值的和大于输入的整数data,则将不进行加法运算,直接回退;如果与当前节点值的和刚好等于sum,且当前节点为叶子节点,则打印该路径,然后回退;如果与当前节点值得和小于data,则继续向下计算……,这样的做法似乎很合理,其实呢?很显然,如果这样做,我们就为问题添加了一个条件:即二元树上的元素值均为正数!!!题目显然没有给出这个条件。自然算法就错了……
正确的做法应该是这样的:首先当然仍要保存搜索的路径,并记录当前路径上所有元素的和sum。如果当前节点为叶子节点,并且当前节点值与sum的和等于data,则满足条件,打印后递归返回到父节点,注意在打印后、递归返回之前要先减去当前节点元素的值;如果当前节点不是叶子节点,则不必判断当前节点值与sum的和是否等于data,继续访问子节点……
另一种类似的方法不用录当前路径上所有元素的和sum,而是使用期望的和依次减去访问到的节点的值……最后是判断到达叶子节点时期望和是否减为0,其实时类似的……看代码实现:
#include<stdio.h>
#include<stdlib.h>
#define MAX 20
struct BiTreeNode
{
int data;
struct BiTreeNode *left;
struct BiTreeNode *right;
};
/*递归创建二叉排序树,以'-1'结束*/
BiTreeNode * CreateBSTree()
{
int data;
BiTreeNode * tr;
scanf("%d",&data);
if(data==-1)
{
return NULL;
}
else
{
tr = (BiTreeNode *)malloc(sizeof(BiTreeNode));
tr->data=data;
tr->left = CreateBSTree();
tr->right = CreateBSTree();
return tr;
}
}
//中序遍历二叉树
void InOrderTraverse(BiTreeNode * root)
{
if(root->left)
InOrderTraverse(root->left);
if(root)
printf("%d ",root->data);
if(root->right)
InOrderTraverse(root->right);
}
void printPath(int path[],int top)
{
printf("第一组:");
for(int i=0;i<top;i++)
printf("%d ",path[i]);
printf("\n");
}
void findPath(BiTreeNode *root, int sum,int top,int path[])
{
path[top++] = root->data;
sum -= root->data;
if (root->left == NULL && root->right==NULL)
{
if (sum == 0)
{
printPath(path, top);
}
}
else
{
if (root->left != NULL)
findPath(root->left, sum, top,path);
if (root->right!=NULL)
findPath(root->right, sum, top,path);
}
top --;
sum += root->data;
}
int main()
{
freopen("input.txt","r",stdin);
BiTreeNode * root=CreateBSTree();
InOrderTraverse(root);
printf("\n");
int sum=22;
int top=0;
//scanf("%d",&sum);
int path[MAX]={0};
findPath(root,sum,top,path);
getchar();
return 0;
}
|
分享到:
相关推荐
这其中包括了二元查找树转换为排序双向链表、设计包含min函数的栈、求子数组的最大和、在二元树中找出和为某一值的所有路径、查找最小的k个元素等题目。这些题目都是常见的数据结构和算法面试题目,旨在考察面试者的...
在MATLAB中,路径规划是解决机器人导航、城市遍历问题的关键技术之一。这个压缩包文件"matla路径规划城市遍历机器人路径等问题精讲:9 求一元二元函数的最小值和零点.zip"显然包含了关于如何利用MATLAB求解一元和...
知识点四: 在二元树中找出和为某一值的所有路径 在这道题中,我们需要在一个二元树中找出所有和为某一值的路径。为了实现这一目标,我们需要对二元树进行遍历,并使用合适的算法来计算路径的和。 知识点五: 查找...
并集操作可以将两个集合的所有元素合并到一个集合中,交集操作找出两个集合共有的元素,而差集则表示在第一个集合中存在的但不在第二个集合中的元素。理解这些操作对于数据结构和算法的设计至关重要。 3. **判断...
四、在二元树中找出和为某一值的所有路径 这个问题要求输入一个整数和一棵二元树,从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径,打印出和与输入整数相等的所有路径。解答中,我们使用回溯...
在二元树中找出和为某一值的所有路径 此题目要求在给定的二元树中,找到所有节点值之和等于给定整数值的路径。这通常可以通过深度优先搜索(DFS)算法来实现,从根节点开始递归地遍历整个树,同时计算从根节点到...
4. 在二元树中找出和为某一值的所有路径:本题目考察了二元树和算法的知识,要求从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径,并打印出和与输入整数相等的所有路径。解决方法是使用递归算法...
4. 在二元树中找出和为某一值的所有路径: - 该问题要求在二元树中找出从根节点到叶子节点的所有路径,这些路径上的节点值之和等于给定值。 - 需要使用深度优先搜索(DFS)算法,递归遍历二元树的所有节点,并将...
5. 在二元树中找出和为某一值的所有路径:这是一个递归遍历二元树并记录路径和的问题。可以通过深度优先搜索(DFS)来实现,在递归过程中累加路径上的节点值,当达到叶子节点且路径和等于目标值时,记录该路径。 **...
**五、在二元树中找出和为某一值的所有路径** 在二元树中找出所有和为特定值的路径,通常采用深度优先搜索(DFS)策略。从根节点开始,递归地探索每条可能的路径,同时维护一条路径上的节点值总和。当到达叶子节点...
4. 在二元树中找出和为某一值的所有路径 知识点:二元树遍历、路径问题、回溯法 要找出二元树中所有和为目标值的路径,可以使用回溯法。从根节点开始,递归遍历每个节点,并记录当前路径的和。当达到叶节点时,判断...
在二元树中找出和为某一值的所有路径 **题目描述**:给定一个整数target和一棵二元树,找出所有路径上的节点值之和等于target的路径。 **解决方案**:采用深度优先搜索(DFS)策略。从根节点开始递归,每经过一个...
4. 在二元树中找出和为某一值的所有路径 本题目要求输入一个整数和一棵二元树。从树的根结点开始往下访问一直到叶结点所经过的所有结点形成一条路径。打印出和与输入整数相等的所有路径。解决这个问题的关键是正确...
#### 2.2 在二元树中找出和为某一值的所有路径 **题目概述**:给定一个整数值和一棵二元树,找出所有从根节点到叶子节点的路径,使得路径上所有节点值的和等于给定的整数值。 **解题思路**: - 采用深度优先搜索...
5. 二元树中找出和为某一值的所有路径: 这个问题可以通过深度优先搜索(DFS)来解决,需要递归地在树中寻找所有可能的路径,直到找到总和等于目标值的路径。 ***K算法: TopK算法涉及到在一组数中找出前k个最大...
在二元树中找出和为某一值的所有路径 **知识点概述:** 本题要求在一个二元树中找到所有路径,使得路径上节点的值之和等于给定的目标值。 **核心思想:** - **深度优先搜索**:采用深度优先搜索的方式遍历二元树...
在二元树中找出和为某一值的所有路径 - **题目概述**:给定一个整数`target`和一棵二元树,找出所有从根节点到叶子节点路径上的节点值之和等于`target`的路径。 - **关键概念**: - **递归**:一种通过调用自身...
例如,传递闭包可以通过Warshall算法来求解,这是一个简单的迭代过程,用于找出所有可能的传递路径。自反和对称闭包则相对直观,只需要直接添加对应的元素对即可。 至于“可视化”,这通常指的是通过图形界面展示...