【Golang】LeetCode 118. 杨辉三角

118. 杨辉三角

题目描述

思路

只要在中学阶段稍微接触过竞赛程度的稍微较难的数学题,那么一定听说过杨辉三角。其实对于计算机科班的同学,在本科学习基础语言的时候大概率在多维数组、动态规划基础等部分接触过杨辉三角。

这道题目也与杨辉三角相关,那就是基于给定的行数,构建出一个杨辉三角。

思路其实也很简单,按照要求构建即可,这是一道披着模拟外衣的动态规划问题。但是需要注意的是,要求返回的答案其实是一个多维的vector,也就是多维数组的第一个元素只有一维,第二行有二维,依此类推。

针对 Golang 而言,我们通过make([][]int, numRows)得到的序列,其实是一个元素是序列的序列,其中每个元素还没有被初始化,因此默认是 Golang 的零值,也就是空的应该指向整型序列的指针,我们需要显式地对每一行进行初始化,也就是使用make([]int, i + 1)。在初始化的过程中,我们可以显式地对这一行的第一个数和最后一个数进行初始化,从而方便在第二次遍历时直接从上到下对杨辉三角按规则进行维护。

Golang 题解

go 复制代码
func generate(numRows int) [][]int {
    ans := make([][]int, numRows)
    for i := 0; i < numRows; i ++ {
        ans[i] = make([]int, i + 1)
        ans[i][0], ans[i][i] = 1, 1
    }

    for i := 2; i < numRows; i ++ {
        for j := 1; j < i; j ++ {
            ans[i][j] = ans[i - 1][j - 1] + ans[i - 1][j]
        }
    }

    return ans
}
相关推荐
05候补工程师15 小时前
【408狂飙·数据结构】核心考点深度复盘:数组地址计算、特殊矩阵压缩存储与树的五大性质解题直觉
数据结构·笔记·线性代数·考研·算法·矩阵
青山师15 小时前
HashMap深度解析:哈希冲突、扩容机制与线程安全
算法·安全·哈希算法·java面试·hashmap源码
货拉拉技术15 小时前
私域转化率翻倍的秘密:我们把多模态Agent融进了私域营销
人工智能·算法·设计模式
WL_Aurora15 小时前
备战蓝桥杯国赛【Day 17】
算法·蓝桥杯
kcuwu.15 小时前
决策树与集成学习深度解析:从原理到实践
算法·决策树·集成学习
programhelp_16 小时前
2026 Fall Coinbase Software Engineer OA 真题分享与通关指南
算法
CQU_JIAKE16 小时前
5.19【A】
算法
数智工坊16 小时前
【FDA论文阅读】: 傅里叶域自适应——零训练成本的语义分割无监督域适配方法
论文阅读·人工智能·学习·算法·自动驾驶
承渊政道16 小时前
【贪心算法】(经典实战应用解析(五):单调递增的数字、坏了的计算器、合并区间、⽆重叠区间、⽤最少数量的箭引爆⽓球)
数据结构·c++·leetcode·贪心算法·排序算法·动态规划·哈希算法
Gauss松鼠会16 小时前
【GaussDB】GaussDB 常见问题及解决方案汇总
java·数据库·算法·性能优化·gaussdb·经验总结