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

总结:

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

相关推荐
上海观智网络9 分钟前
上海小程序定制开发合同怎么签?需要注意什么?
经验分享·笔记·小程序
玉小格20 分钟前
一次关于Python的总结
算法
伊甸322 分钟前
从企业级项目学敏感词过滤:DFA算法与双层缓存实战
java·算法·缓存
bIo7lyA8v34 分钟前
算法中的随机化思想及其复杂度收益评估的技术8
算法
数据法师39 分钟前
视频文件重复检测工具:基于哈希与视频指纹的三级筛选机制
算法·音视频·哈希算法
其实防守也摸鱼41 分钟前
软件安全与漏洞--Windows底层原理与软件逆向工程基础
linux·网络·数据库·算法·安全·安全架构·软件安全与漏洞
Ab_stupid43 分钟前
CTF-Crypto培训笔记-现代密码
笔记·des·aes·rsa·crypto
IT技术学习1 小时前
打包系统为ISO
笔记
bIo7lyA8v1 小时前
算法稳定性与数据分布的内在联系研究的技术8
算法
就叫飞六吧2 小时前
数学图形绘制在线网站
笔记