算法基础之数字三角形

数字三角形

  • 核心思想:线性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;
        }
相关推荐
测试员周周2 小时前
【Appium 系列】第16节-WebView-H5上下文切换 — 混合应用的自动化难点
运维·开发语言·人工智能·功能测试·appium·自动化·测试用例
杜子不疼.4 小时前
【C++ AI 大模型接入 SDK】 - DeepSeek 模型接入(上)
开发语言·c++·chatgpt
加号34 小时前
【C#】 串口通信技术深度解析及实现
开发语言·c#
sycmancia5 小时前
Qt——编辑交互功能的实现
开发语言·qt
石山代码6 小时前
C++ 内存分区 堆区
java·开发语言·c++
心中有国也有家6 小时前
cann-recipes-infer:昇腾 NPU 推理的“菜谱集合”
经验分享·笔记·学习·算法
绝知此事6 小时前
【算法突围 01】线性结构与哈希表:后端开发的收纳术
java·数据结构·算法·面试·jdk·散列表
无风听海6 小时前
C# 隐式转换深度解析
java·开发语言·c#
碧海银沙音频科技研究院6 小时前
通话AEC与语音识别AEC的软硬回采链路
深度学习·算法·语音识别
一只大袋鼠7 小时前
Git 进阶(二):分支管理、暂存栈、远程仓库与多人协作
java·开发语言·git