【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
相关推荐
胖达不服输18 分钟前
「日拱一码」087 机器学习——SPARROW
人工智能·python·机器学习·sparrow
GilgameshJSS2 小时前
【学习K230-例程21】GT6700-UDP-Client
网络·python·单片机·网络协议·学习·udp
FriendshipT2 小时前
Nuitka 将 Python 脚本封装为 .pyd 或 .so 文件
开发语言·python
她说人狗殊途2 小时前
动态代理1
开发语言·python
楼田莉子2 小时前
C++动态规划算法:斐波那契数列模型
c++·学习·算法·动态规划
Yvonne爱编码2 小时前
后端编程开发路径:从入门到精通的系统性探索
java·前端·后端·python·sql·go
1白天的黑夜13 小时前
栈-1047.删除字符串中的所有相邻重复项-力扣(LeetCode)
c++·leetcode·
im_AMBER3 小时前
Leetcode 18 java
java·算法·leetcode
Q_Q19632884753 小时前
python+springboot大学生心理测评与分析系统 心理问卷测试 自动评分分析 可视化反馈系统
开发语言·spring boot·python·django·flask·node.js·php
BYSJMG3 小时前
计算机毕设推荐:基于Hadoop+Spark物联网网络安全数据分析系统 物联网威胁分析系统【源码+文档+调试】
大数据·hadoop·python·物联网·spark·django·课程设计