Appearance
118. 杨辉三角
给定一个非负整数 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
- 来源:力扣(LeetCode)
- 链接:https://leetcode.cn/problems/pascals-triangle
javascript
/**
* @param {number} numRows
* @return {number[][]}
*/
var generate = function (numRows) {
const res = [[1], [1, 1], [1, 2, 1]]
if (numRows === 1) return res.slice(0, 1)
if (numRows === 2) return res.slice(0, 2)
if (numRows === 3) return res.slice(0, 3)
for (let i = 3; i < numRows; i++) {
res[i] = [1]
for (let j = 1; j < i; j++) {
res[i][j] = res[i - 1][j - 1] + res[i - 1][j]
}
res[i].push(1)
}
return res
}
console.log(generate(1))
console.log(generate(2))
console.log(generate(3))
console.log(generate(4))