求二叉树中最大和的路径

博客聚焦信息技术领域,假设二叉树节点值为int类型且采用二叉链存储,设计递归算法来求从根节点到叶子节点路径和最大的一条路径,还提到先序创建二叉树,输入0表示无左孩子或右孩子。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

假设二叉树中所有节点的值为int类型,采用二叉链存储。设计递归算法求二叉树中从根节点到叶子节点路径和最大的一条路径。

先序创建二叉树,输入0表示无左孩子或右孩子
输入方法在这里插入图片描述

#include<iostream>
using namespace std;

typedef struct BiTree
{
	int data;
	struct BiTree *left,*right;
 }BiTree; 
 
 void CreatBiTree(BiTree *&T)
 {
 	int temp;
 	cin>>temp;
 	if(temp!=0)
 	{
 		T=new BiTree;
		T->data=temp;
 		CreatBiTree(T->left);
 		CreatBiTree(T->right);
	 }
	else T=nullptr; //此行报错的话把nullptr改为NULL
 }

int PathMax(BiTree *T)
{
	if(T==0)return 0;
	else
	{
		return max(T->data+PathMax(T->left),T->data+PathMax(T->right));
	}
}

void Path(BiTree *T)
{
	if(T)
	{
		cout<<T->data<<' ';
		if(PathMax(T->left)>=PathMax(T->right))
		{
			Path(T->left);
		}
		else
		{
			Path(T->right);
		}
	 } 
}

int main()
{
	BiTree *T;
	CreatBiTree(T);
	cout<<"+++++++++++++++++++++++++++++++++++++"<<endl;
	cout<<"最大和:"<<PathMax(T)<<endl<<"此路径为:";
	Path(T);
	return 0;
}
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值