数字三角形问题(动态规划算法)

算法 专栏收录该内容
6 篇文章 0 订阅

问题描述

给字一个由n行数字组成的数字三角形(等腰三角形)。试设计一个算法,计算出从三角形的顶至底的一条路径,使该路径经过的数字总和最大。

输入

数字三角形的行数和数字三角形

输出

最大的路径和以及路径

输入样例

5
7
8 3
9 8 7
1 2 3 4
4 5 6 7 8

输出样例

33
7 8 8 3 7

提示

输入:请输入数字三角形的行数:
请输入数字三角形:

输出:路径总和最大为:
自顶向下的路径为:

完整代码:

#include "stdafx.h"
int main(int argc, char* argv[])
{
	int i,j,n;
	int a[100][100];//用于存放三角形
	int b[100][100];//用于复制a数组
	printf("请输入数字三角形的行数:\n");
	scanf("%d",&n);//获取输入的行数
    printf("请输入数字三角形:\n");
	for(i=1;i<=n;i++){
        for(j=1;j<=i;j++){
              scanf("%d",&a[i-1][j-1]);//输入三角形
			  b[i-1][j-1]=a[i-1][j-1];//复制
		}	
	}
	for(int row=n-2;row>=0;row--){//从倒数第二行开始往上递推
		for(int col=0;col<=row;col++){
			if(a[row+1][col]>a[row+1][col+1]){//将每个数下面的两个数进行比较
                 a[row][col]+=a[row+1][col]; //取较大的数加	
			}
			else{
                a[row][col]+=a[row+1][col+1];
			}
		}
	}
	printf("路径总和最大为:\n");
	printf("%d\n",a[0][0]);
	printf("自顶向下的路径为:\n");
	printf("%d ",b[0][0]);//先输出第一行的数字
    int l=0;//定义列
   	for(int m=1;m<n;m++){//从第二行开始往下递推
			if(a[m][l]>a[m][l+1]){
                    printf("%d ",b[m][l]);//根据数值较大的数的位置输出b数组中指定位置的值
			}else{
                    printf("%d ",b[m][l+1]);
					l=l+1;//如果较大的数为右边的数则下次开比较的列加1
			}	   
	}
	 printf("\n");
	 return 0;
}

测试

测试用例1:根据提示输入数字三角形的行数为5,输入数字三角形为
7
8 3
9 8 7
1 2 3 4
4 5 6 7 8
回车后系统显示路径总和最大的值为33,以及自顶向下的路径为7 8 8 3 7
在这里插入图片描述

测试用例2:根据提示输入数字三角形的行数为6,输入数字三角形为
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
7 8 9 10 11 12
回车后系统显示路径总和最大的值为39,以及自顶向下的路径为7 3 8 7 5 9
在这里插入图片描述

  • 5
    点赞
  • 0
    评论
  • 12
    收藏
  • 一键三连
    一键三连
  • 扫一扫,分享海报

打赏
文章很值,打赏犒劳作者一下
相关推荐
©️2020 CSDN 皮肤主题: 创作都市 设计师:CSDN官方博客 返回首页

打赏

nepu_hua

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值