算法基础之数字三角形

数字三角形

  • 核心思想:线性dp

    • 集合的定义为 f[i][j] --> 到i j点的最大距离

    • 从下往上传值 父节点f[i][j] = max(f[i+1][j] , f[i+1][j+1]) + w[i][j]

    • 初始化最后一层 f = w

    cpp 复制代码
      #include <bits/stdc++.h>
      
      using namespace std;
      
      const int N = 510;
      
      int w[N][N],f[N][N];
      int n;
      
      int main()
      {
          cin >> n;
          for (int i = 1; i <= n; i++)
              for (int j = 1; j <= i; j++)
                  cin >> w[i][j];
      
          for(int i=1;i<=n;i++) f[n][i] = w[n][i]; 
          for (int i = n - 1; i >= 1; i--)
              for (int j = 1; j <= i; j++)
                  f[i][j] = max(f[i + 1][j + 1], f[i + 1][j]) + w[i][j];  //左孩子和右孩子取最大 + 距离
      
          cout << f[1][1] << endl;
      }
    • 优化版:

      cpp 复制代码
        #include <bits/stdc++.h>
        
        using namespace std;
        
        const int N = 510;
        
        int f[N][N];
        int n;
        
        int main()
        {
            cin >> n;
            for (int i = 1; i <= n; i++)
                for (int j = 1; j <= i; j++)
                    cin >> f[i][j];
        
            for (int i = n - 1; i >= 1; i--)
                for (int j = 1; j <= i; j++)
                    f[i][j] = max(f[i + 1][j + 1], f[i + 1][j]) + f[i][j];
            		//用完f[i][j]距上一层距离 就将其更新成距底部距离
        
            cout << f[1][1] << endl;
        }
相关推荐
梯度下降中5 分钟前
LoRA原理精讲
人工智能·算法·机器学习
IronMurphy10 分钟前
【算法三十一】46. 全排列
算法·leetcode·职场和发展
czlczl2002092510 分钟前
力扣1911. 最大交替子序列和
算法·leetcode·动态规划
Amour恋空11 分钟前
Java多线程
java·开发语言·python
小陈工16 分钟前
2026年3月28日技术资讯洞察:5G-A边缘计算落地、低延迟AI推理革命与工业智造新范式
开发语言·人工智能·后端·python·5g·安全·边缘计算
第二只羽毛38 分钟前
C++ 高并发内存池1
大数据·开发语言·c++·开源
不想看见4041 小时前
C++/Qt 实习岗位深度解析【结合一次研发实习谈感受】
开发语言·c++·qt
靴子学长1 小时前
Decoder only 架构下 - KV cache 的理解
pytorch·深度学习·算法·大模型·kv
王老师青少年编程1 小时前
信奥赛C++提高组csp-s之组合数学专题课:鸽巢原理详解及案例实践
c++·组合数学·信奥赛·抽屉原理·csp-s·提高组·鸽巢原理
sjmaysee1 小时前
Java框架SpringBoot(一)
java·开发语言·spring boot