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]即可解决

相关推荐
无名-CODING2 分钟前
栈与队列学习笔记
java·笔记
Hui Baby4 分钟前
LSM 原理、实现及与 B+ 树的核心区别
java·linux·算法
NZT-485 分钟前
C++基础笔记(二)队列deque,queue和堆priority_queue
java·c++·笔记
爬山算法21 分钟前
Netty(13)Netty中的事件和回调机制
java·前端·算法
CoovallyAIHub28 分钟前
是什么支撑L3自动驾驶落地?读懂AI驾驶与碰撞预测
深度学习·算法·计算机视觉
YJlio29 分钟前
ZoomIt 学习笔记(11.7):安装与基础使用——演示/授课/录屏的神级放大镜
笔记·学习·intellij-idea
玉树临风ives35 分钟前
atcoder ABC436 题解
c++·算法·leetcode·atcoder·信息学奥赛
圣保罗的大教堂39 分钟前
leetcode 2110. 股票平滑下跌阶段的数目 中等
leetcode
patrickpdx39 分钟前
leetcode:相等的有理数
算法·leetcode·职场和发展
dragoooon341 小时前
[C++——lesson29.数据结构进阶——「AVL树」]
算法