【leetcode100】杨辉三角

1、题目描述

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

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

示例 1:

复制代码
输入: numRows = 5
输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]

示例 2:

复制代码
输入: numRows = 1
输出: [[1]]

2、初始思路

2.1 思路

使用动态规划

1、确定dp数组及其含义

dp数组表示的是杨辉三角各个点的值

2、确定递推公式

题目中已经给出"在「杨辉三角」中,每个数是它左上方和右上方的数的和。",因此,递推公式可表示为:

复制代码
dp[i][j] = dp[i-1][j-1] + dp[i-1][j]

3、初始化dp数组

通过观察,可以将杨辉三角初始化为每层递加的[1],如下:

复制代码
dp = [[1] * (i+1) for i in range(numRows)]

2.2 完整代码

复制代码
class Solution:
    def generate(self, numRows: int) -> List[List[int]]:
        dp = [[1]*(i+1) for i in range(numRows)]
        for i in range(2,numRows):
            for j in range(1,i):
                dp[i][j] = dp[i-1][j-1] + dp[i-1][j]
        return dp
相关推荐
百年孤独_几秒前
单周期 MIPS 数据通路上层视角
python
2501_90120053几秒前
进阶设计指南之如何打印分页与自适应ER图_支持高级扩展类型
jvm·数据库·python
m0_609160492 分钟前
C#怎么实现HttpClient最佳实践 C#如何用IHttpClientFactory管理HttpClient避免端口耗尽【网络】
jvm·数据库·python
zjy277775 分钟前
Quill 编辑器光标意外跳转至顶部的解决方案
jvm·数据库·python
2301_766283446 分钟前
MySQL数据误删除后如何快速恢复_基于binlog日志的闪回操作
jvm·数据库·python
duke8692672147 分钟前
Bootstrap中常用的文本颜色、背景颜色及边框色类
jvm·数据库·python
m0_7403524212 分钟前
React 中的渲染(Rendering)机制详解.txt
jvm·数据库·python
张小凡vip12 分钟前
python单元测试详解
开发语言·python·单元测试
weixin_4440129313 分钟前
WooCommerce 用户登录状态控制元素显隐的 CSS 实现方案
jvm·数据库·python
kexnjdcncnxjs13 分钟前
CSS Grid布局如何实现固定页脚效果_利用网格高度视口百分比单位
jvm·数据库·python