【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
相关推荐
lili00123 分钟前
Claude自动修Bug配置优化与避坑指南
java·人工智能·python·bug·ai编程
金牌归来发现妻女流落街头4 分钟前
【LeetCode 第207题】
算法·leetcode·拓扑·领接表
Szime6 分钟前
靠谱的终端工厂采购电子元器件供应链哪家更适合研发型企业?
人工智能·python
2401_8734794011 分钟前
如何用IP离线库批量清洗订单IP,自动标注省市区?
开发语言·网络·python
py小王子12 分钟前
期刊复现 | Python实现扇形小提琴图
python·期刊图片复现
godspeed_lucip32 分钟前
LLM和Agent——专题5: LLM Ops 入门(2)
人工智能·python
技术钱32 分钟前
RAG 开发 6 个阶段优化策略分析
python
QFIUNE36 分钟前
使用 MMseqs2 计算多个 DTI 数据集的蛋白序列相似度
linux·python·ubuntu
念恒1230643 分钟前
Python 函数完全指南:定义与调用
开发语言·python
大数据魔法师1 小时前
Streamlit(十二)- API 参考文档(五)- 输入组件
python·web