给定一个非负整数 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
题解:
/**
* @param {number} numRows
* @return {number[][]}
*/
var generate = function (numRows) {
let res = []
for (let i = 0; i < numRows; i++) {
// 当前行填充默认数值
const row = new Array(i + 1).fill(1)
for (let j = 1; j < row.length - 1; j++) {
// 循环计算 当前行每个数字等于上一行的左右两个数字之和,
row[j] = res[i - 1][j - 1] + res[i - 1][j]
}
res.push(row)
}
return res
};