LeetCode热题100--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]]

题解

java 复制代码
class Solution {
    public List<List<Integer>> generate(int numRows) {
        List<List<Integer>> c = new ArrayList<>(numRows); // 预分配空间
        c.add(List.of(1));
        for (int i = 1; i < numRows; i++) {
            List<Integer> row = new ArrayList<>(i + 1); // 预分配空间
            row.add(1);
            for (int j = 1; j < i; j++) {
                // 左上方的数 + 正上方的数
                row.add(c.get(i - 1).get(j - 1) + c.get(i - 1).get(j));
            }
            row.add(1);
            c.add(row);
        }
        return c;
    }
}

解析

出自:简单题,简单做(Python/Java/C++/C/Go/JS/Rust)

java 复制代码
class Solution  {    //定义一个新的解决方案类
   public List<List<Integer>> generate(int numRows) {      //此函数接受一个字符串s作为输入参数,用于匹配回文。返回值为布尔类型(True if s is a palindrome, False otherwise)
       List<List<Integer>> c = new ArrayList<>(numRows);   //在这里创建一个空的二维列表(可变长度数组)来存储所有三角形行。这个列表最多有'numRows'个子元素,每个子元素都表示一个帕斯卡三角形行
       c.add(List.of(1));                                 //将第一个值[1]添加到我们的二维列表中
       for (int i = 1; i < numRows; i++) {                   //从第二个数字开始(因为帕斯卡三角形的每个行都有一个'1'作为前缀和后缀,所以我们从1开始循环)。在这里'i'表示每一行的索引号
           List<Integer> row = new ArrayList<>(i + 1);       //创建一个新的ArrayList来存储每一行的数字。它的容量将等于行数+1(因为每个帕斯卡三角形行都有一个额外的'1'作为后缀)
           row.add(1);                                         //由于每个帕斯卡三角形行的起始有一个'1',所以将第一个值[1]添加到我们的新创建的ArrayList中
           for (int j = 1; j < i; j++) {                      //这个循环用于获取每一行中的第j个计算出的元素。在这里'j'从我们的第二个值开始,一直到索引为i(不包括最大数)
                row.add(c.get(i - 1).get(j - 1) + c.get(i - 1).get(j)); //计算第i-th行中第j个数字。它是帕斯卡三角形中的左上方和正上方的元素之和
           }   
           row.add(1);                                         //由于每个帕斯科三角形行的结尾有一个'1',所以将最后一个值[1]添加到我们的新创建的ArrayList中
           c.add(row);                                          //将每一行添加到我们的二维列表c中 
        }
相关推荐
图码22 分钟前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
handler0130 分钟前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
minglie137 分钟前
实数列的常用递推模式
算法
代码小书生1 小时前
math,一个基础的 Python 库!
人工智能·python·算法
AI科技星1 小时前
全域数学·数术本源·高维代数卷(72分册)【乖乖数学】
人工智能·算法·数学建模·数据挖掘·量子计算
生成论实验室1 小时前
《事件关系阴阳博弈动力学:识势应势之道》第一篇:生成正在发生——从《即事经》到事件-关系网络
人工智能·科技·算法·架构·创业创新
漂流瓶jz1 小时前
UVA-1152 和为0的4个值 题解答案代码 算法竞赛入门经典第二版
数据结构·算法·二分查找·题解·aoapc·算法竞赛入门经典·uva
leoufung1 小时前
LeetCode 76:Minimum Window Substring 题解与滑动窗口思维详解
算法·leetcode·职场和发展
小O的算法实验室1 小时前
2026年IEEE TETCI,山区环境下基于双种群进化的协同无人机巡逻任务协同优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
生成论实验室2 小时前
《事件关系阴阳博弈动力学:识势应势之道》第二篇:阴阳博弈——认知的动力学基础
数据结构·人工智能·科技·神经网络·算法