目录

LC 118. 杨辉三角 (opens new window) (opens new window)

简单

# 问题描述

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

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

杨辉三角

示例 1:

输入: numRows = 5
输出: [[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]

示例 2:

输入: numRows = 1
输出: [[1]]

提示:

  • 1 <= numRows <= 30

# 动态规划

假设层数为 ii,那么第 ii 层就有 ii 个元素,且首尾是 11,假设 dp[i][j]dp[i][j] 表示第 ii 层,第 jj 个数,那么对于 i>0i > 00<j<i0 < j < i 就有: dp[i][j]=dp[i1][j1]+dp[i1][j]dp[i][j] = dp[i-1][j-1] + dp[i-1][j]

/**
 * @param {number} numRows
 * @return {number[][]}
 */
var generate = function (numRows) {
  const dp = []
  dp[0] = [1]
  for (let i = 1; i < numRows; i++) {
    dp[i] = [1]
    for (let j = 1; j < i; j++) {
      dp[i][j] = dp[i - 1][j - 1] + dp[i - 1][j]
    }
    dp[i][i] = 1
  }
  return dp
}
  • 时间复杂度:O(n2)O(n^2)
  • 空间复杂度:O(1)O(1),不考虑返回值的空间占用。
上次更新: 2023/01/31 19:48:05

本博客所有文章除特别声明外,均采用 CC BY-SA 4.0 协议 , 转载请注明出处!