算法(TS):杨辉三角

给定一个非负整数 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

解法

第一行固定为[1],第二行固定为[1,1],其余行中每个数的计算公式为 (prevRow[j] || 0) + (prevRow[j-1] || 0),第1行1个数,第2行2个数,第3行3个数,以此类推。

ts 复制代码
function generate(numRows: number): number[][] {
    const res = []
    
    for(let i = 0; i < numRows; i++) {
        if(i===0) {
            res.push([1])
            continue
        }
        if(i === 1) {
            res.push([1,1])
            continue
        }

        const nums: number[] = []
        const prevRow = res[i-1]
        for(let j = 0; j < i + 1; j++) {
            nums.push((prevRow[j] || 0) + (prevRow[j-1] || 0))
        }

        res.push(nums)
    }
    return res
};

时间复杂度O(numRows*numRows),空间负责度O(1)

相关推荐
Irene19914 分钟前
JavaScript中,为什么需要手动清理事件
javascript·手动清理事件监听器
摘星编程8 分钟前
OpenHarmony环境下React Native:Zustand持久化存储
javascript·react native·react.js
2501_9445215910 分钟前
Flutter for OpenHarmony 微动漫App实战:图片加载实现
android·开发语言·前端·javascript·flutter·php
摘星编程13 分钟前
在OpenHarmony上用React Native:Recoil选择器异步数据
javascript·react native·react.js
雨中深巷的油纸伞24 分钟前
vue 项目部署到iis后 浏览器刷新404
前端·javascript·vue.js
博大世界27 分钟前
matlab结构体数组定义
数据结构·算法
Loo国昌34 分钟前
【LangChain1.0】第九阶段:文档处理工程 (LlamaIndex)
人工智能·后端·python·算法·langchain
Zach_yuan36 分钟前
面向对象封装线程:用 C++ 封装 pthread
开发语言·c++·算法
谢尔登1 小时前
从源码视角来看Pinia!
前端·javascript·vue.js
梦6501 小时前
JavaScript 循环
开发语言·javascript·ecmascript