118.杨辉三角&120.三角形最小路径和

118.杨辉三角&120.三角形最小路径和

118.杨辉三角

思路:其实也是动态规划,相当于题目给出了递推方程

代码:

cpp 复制代码
class Solution {
public:
    vector<vector<int>> generate(int numRows) {
        vector<vector<int>> triangle(numRows);
        for(int i=0;i<numRows;i++){
            triangle[i].resize(i+1,1);
             for(int j=1;j<i;j++){
               //当前值=正上方+左上方(三角形向左对齐后)
                triangle[i][j] = triangle[i - 1][j - 1] + triangle[i - 1][j];
             }
        }
        return triangle;
    }
};

120.三角形最小路径和

思路:动态规划,和网格路径和差不多,主要是边界条件的不同

根据题目要求:相邻的结点 在这里指的是 下标上一层结点下标 相同或者等于 上一层结点下标 + 1 的两个结点

路径有三种情况:

(1)三角形左侧边(对齐后二维数组第一列):路径只能来自于正上方

(2)三角形右侧边(二维数组每一层最后一个):路径只能来自于左上方

(3)普通位置:路径来自于左上方或正上方(取最小值)

最后的结果为最后一行每个位置路径和的最小值

代码:

cpp 复制代码
class Solution {
public:
    int minimumTotal(vector<vector<int>>& triangle) {
        int s=triangle.size();
        vector<vector<int>> dp(s,vector<int>(s));
        dp[0][0]=triangle[0][0];
        //初始化每行第一个,只能从它正上方的元素来
        for(int i=1;i<s;i++){
            dp[i][0]=dp[i-1][0]+triangle[i][0];
        }
        for(int i=1;i<s;i++){
            dp[i].resize(i+1,0);
            for(int j=1;j<=i;j++){
                //最后一个元素只能从左上方的来
                if(j==i){
                    dp[i][j]=dp[i-1][j-1]+triangle[i][j];
                }else{
                    dp[i][j]=min(dp[i-1][j],dp[i-1][j-1])+triangle[i][j];
                }
            }
        }
        return *min_element(dp[s-1].begin(),dp[s-1].end());
    }
};
相关推荐
Black蜡笔小新13 分钟前
自动化AI算法训练服务器DLTM制造业AI质检工作站助力制造业实现AI智检
人工智能·算法·自动化
嵌入式小能手17 分钟前
飞凌嵌入式ElfBoard-进程间的通信之命名管道
linux·服务器·算法
啦哈拉哈39 分钟前
Leetcode题解记录-hot100(81-100)
算法·leetcode·职场和发展
csdn_aspnet1 小时前
Java 霍尔分区算法(Hoare‘s Partition Algorithm)
java·开发语言·算法
诸葛务农1 小时前
道路行驶条件下电动汽车永磁电机的有效使用寿命及永磁体的失效和回收再利用(下)
java·开发语言·算法
snow@li1 小时前
AI:理解 大数据、算法、算力、电力、生成式AI、token 之间的关系
大数据·人工智能·算法
小智老师PMP1 小时前
零基础能不能考PMP?零基础专属学习路径+全套扶持体系
学习·算法·职场和发展·软件工程·求职招聘·敏捷流程
Dillon Dong2 小时前
【风电控制】FPGA采集Vdc的ADC增益系数解析——从数字码到实际电压的桥梁
算法·fpga开发·变流器·风电控制
TDengine (老段)2 小时前
TDengine 压缩编码机制 — 双层压缩架构与类型特化算法
大数据·数据库·物联网·算法·时序数据库·tdengine·涛思数据
妄想出头的工业炼药师3 小时前
LVIO鲁棒
算法·开源