leetcode做题笔记118. 杨辉三角

给定一个非负整数 numRows 生成「杨辉三角」的前 *numRows*行。

在「杨辉三角」中,每个数是它左上方和右上方的数的和。

思路一:动态规划

cpp 复制代码
int** generate(int numRows, int* returnSize, int** returnColumnSizes){
    int **returnnum=(int **)malloc(sizeof(int *)*numRows);
    *returnSize = numRows;
    *returnColumnSizes = malloc(sizeof(int) * numRows);
    int i,j;
    for(i=0;i<numRows;i++){
        returnnum[i]=(int *)malloc(sizeof(int)*(i+1));
        (*returnColumnSizes)[i]=i+1;
        returnnum[i][0]=1;
        returnnum[i][i]=1;
        if(i>=2){
            for(j=1;j<i;j++){
                returnnum[i][j]=returnnum[i-1][j-1]+returnnum[i-1][j];
            }
        }
    }
    return returnnum;
}

分析:

本题要求杨辉三角,每个数为上一行相同位置和前一位数之和,可用循环将每个数利用上一行计算出来,最后输出dp,即returnnum

总结:

本题考察动态规划的应用,找到状态方程dp[i][j] = dp[i-1][j-1]+dp[i-1][j]即可解决

相关推荐
im_AMBER4 分钟前
React 09
前端·javascript·笔记·学习·react.js·前端框架
mifengxing9 分钟前
力扣每日一题——接雨水
c语言·数据结构·算法·leetcode·动态规划·
codeyanwu1 小时前
SQL 学习笔记
笔记·sql·学习
魔云连洲1 小时前
前端树形结构过滤算法
前端·算法
小龙报1 小时前
《算法通关指南:数据结构和算法篇 --- 顺序表相关算法题》--- 询问学号,寄包柜,合并两个有序数组
c语言·开发语言·数据结构·c++·算法·学习方法·visual studio
71-31 小时前
C语言——函数声明、定义、调用
c语言·笔记·学习·其他
小南家的青蛙2 小时前
LeetCode LCR 085 括号生成
算法·leetcode·职场和发展
jackzhuoa2 小时前
Rust 异步核心机制剖析:从 Poll 到状态机的底层演化
服务器·前端·算法
夜晚中的人海2 小时前
【C++】模拟算法习题
c++·算法·哈希算法
花月C2 小时前
算法 - 差分
人工智能·算法·机器学习