leetcode——杨辉三角(简单移动的解法)

给定一个非负整数 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.杨辉三角中每个数的左上方的数与其右上方的数相加等于该数,所以我们需要两层循环来解题。

2.首先第一层循环是我们行的遍历,然后第二层循环是我们的列的遍历。

3.记得每一次退出第二层循环的时候我们需要在该行的末尾加上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;
    }
}
相关推荐
硕风和炜16 分钟前
【LeetCode: 378. 有序矩阵中第 K 小的元素 + 二分】
java·算法·leetcode·面试·矩阵·二分
夏末秋也凉32 分钟前
力扣-栈与队列-347 前k个高频元素
数据结构·算法·leetcode
南宫生36 分钟前
力扣动态规划-23【算法学习day.117】
java·学习·算法·leetcode·动态规划
Tisfy39 分钟前
LeetCode 0063.不同路径 II:动态规划 - 原地使用地图数组,几乎无额外空间开销
算法·leetcode·动态规划·题解·dp
gentle_ice1 小时前
搜索二维矩阵——巧用右上角起点搜索法,高效解决二维矩阵查找问题
数据结构·算法·leetcode·矩阵
_不会dp不改名_2 小时前
leetcode_80删除有序数组中的重复项 II
数据结构·算法·leetcode
√尖尖角↑2 小时前
力扣——【104. 二叉树的最大深度】
python·算法·leetcode
幸运小圣2 小时前
LeetCode热题100- 轮转数组【JavaScript讲解】
javascript·算法·leetcode
MYX_3092 小时前
第七节 文件与流
开发语言·c++·学习·算法
Lostgreen2 小时前
解密K-means:简单易懂的算法指南
算法·机器学习·kmeans