Acwing.898 数字三角形(动态规划)

题目

给定一个如下图所示的数字三角形,从顶部出发,在每一结点可以选择移动至其左下方的结点或移动至其右下方的结点,一直走到底层,要求找出─条路径,使路径上的数字的和最大。

输入格式

第一行包含整数n,表示数字三角形的层数。

接下来n行,每行包含若干整数,其中第i行表示数字三角形第i层包含的整数。

输出格式

输出一个整数,表示最大的路径数字和。

数据范围

1 ≤n ≤500,

---10000<三角形中的整数≤10000

  • 输入样例:
java 复制代码
5
7
3 8
8 1 0
2 7 4 4
4 5 2 6 5
  • 输出样例:
java 复制代码
30

题解

java 复制代码
import java.util.Scanner;

/**
 * @author akuya
 * @create 2023-07-24-19:48
 */
public class DigitalTriangle {
    static int N=510;
    static int n;
    static int f[][]=new int[N][N];
    static int a[][]=new int[N][N];
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        n=scanner.nextInt();
        for(int i=1;i<=n;i++){
            for(int j=1;j<=i;j++){
                a[i][j]=scanner.nextInt();
            }
        }


        for(int i=0;i<n+1;i++){
            for(int j=0;j<n+1;j++){
                f[i][j]=-1;
            }
        }

        f[1][1]=a[1][1];

        for(int i=2;i<=n;i++){
            for(int j=1;j<=i;j++){
                f[i][j]=Math.max(f[i-1][j]+a[i][j],f[i-1][j-1]+a[i][j]);
            }
        }

        int res=-99;
        for(int i=1;i<=n;i++)res=Math.max(res,f[n][i]);


        System.out.println(res);
    }
}

思路

与背包问题一样,属于动态规划的最基本题型,每个点只需要确定左上与右上最大值即可。如图

相关推荐
闲人不梦卿几秒前
数据结构之排序方法
数据结构·算法·排序算法
TracyCoder123几秒前
LeetCode Hot100(24/100)——21. 合并两个有序链表
算法·leetcode·链表
power 雀儿3 分钟前
前馈网络+层归一化
人工智能·算法
爱吃rabbit的mq5 分钟前
第10章:支持向量机:找到最佳边界
算法·机器学习·支持向量机
木非哲9 分钟前
AB实验高级必修课(四):逻辑回归的“马甲”、AUC的概率本质与阈值博弈
算法·机器学习·逻辑回归·abtest
兩尛20 分钟前
45. 跳跃游戏 II
c++·算法·游戏
执风挽^32 分钟前
Python_func_basic
开发语言·python·算法·visual studio code
努力d小白35 分钟前
leetcode438.找到字符串中所有字母异位词
java·javascript·算法
tangchao340勤奋的老年?36 分钟前
ADS通信 C++ 设置通知方式读取指定变量
开发语言·c++·算法
wangluoqi36 分钟前
26.2.5练习总结
数据结构·算法