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);
    }
}

思路

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

相关推荐
郝学胜-神的一滴2 分钟前
GLSL语法详解:从入门到实战
c++·算法·图形渲染
qq_463408424 分钟前
React Native跨平台技术在开源鸿蒙中使用内置的`fetch` API或者第三方库如`axHarmony`来处理网络通信HTTP请求
javascript·算法·react native·react.js·http·开源·harmonyos
蒙奇D索大5 分钟前
【数据结构】考研408 | 散列查找性能剖析:装填因子、冲突策略与优化全攻略
数据结构·考研·算法·哈希算法·改行学it
88号技师7 分钟前
2025年10月一区SCI-中心碰撞优化算法Centered Collision Optimizer-附Matlab免费代码
开发语言·算法·数学建模·matlab·优化算法
zore_c9 分钟前
【数据结构】堆——超详解!!!(包含堆的实现)
c语言·开发语言·数据结构·经验分享·笔记·算法·链表
月明长歌16 分钟前
【码道初阶】【LeetCode387】如何高效找到字符串中第一个不重复的字符?
java·开发语言·数据结构·算法·leetcode·哈希算法
罗湖老棍子17 分钟前
C++ 自定义排序与优先队列运算符重载
数据结构·c++·算法··优先队列·运算符重载
毅炼19 分钟前
hot100打卡——day01
算法
Wang2012201320 分钟前
AI 相关的算法;架构等专有名称总结和介绍
人工智能·算法·架构
良木生香26 分钟前
【数据结构-初阶】二叉树(1)---树的相关概念
c语言·数据结构·算法·蓝桥杯