树塔.cpp

来自「这是学习动态规划时用动态规划设计分析实际问题」· C++ 代码 · 共 52 行

CPP
52
字号
#include"iostream"
using namespace std;
void main()
{
	int a[100][100];
	int b[100][100]={0};
	int n,i,j;
	 cout<<"输入数塔层数n:";
	cin>>n;cout<<endl;

	for(i=0;i<n;i++)
		for(j=0;j<=i;j++)
			cin>>a[i][j];
		

  cout<<"此数塔为:"<<endl;
	{   for(i=0;i<n;i++)
      {
		   for(j=0;j<=i;j++)
			 {   
				cout<<" ";
				cout<<a[i][j];
			 }
				cout<<endl;
		}
	}
	for(i=0;i<n;i++)
		b[n-1][i]=a[n-1][i];

	for( i=n-2;i>=0;i--)
		for( j=0;j<=n-1;j++)
		{
			if(b[i+1][j]>b[i+1][j+1])
				b[i][j]=a[i][j]+b[i+1][j];
			else 
				b[i][j]=a[i][j]+b[i+1][j+1];
		}
		cout<<"此数塔路径的最大值:"<<b[0][0]<<endl;
	cout<<"此数塔最大值的路径为:";
	 j=0;
		for(i=0;i<n;i++)
		{
			if(b[i][j]>b[i][j+1])
				j=j;
			else
				j=j+1;
			cout<<a[i][j]<<"->";
			
		}
	cout<<"和最大值"<<b[0][0]<<endl;
	cout<<endl;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?