​LeetCode刷题实战119: 杨辉三角 II

共 1663字,需浏览 4分钟

 ·

2020-12-11 03:29

算法的重要性,我就不多说了吧,想去大厂,就必须要经过基础知识和业务逻辑面试+算法面试。所以,为了提高大家的算法能力,这个公众号后续每天带大家做一道算法题,题目就从LeetCode上面选 !

今天和大家聊的问题叫做 杨辉三角 II,我们先来看题面:
https://leetcode-cn.com/problems/pascals-triangle-ii/

Given an integer rowIndex, return the rowIndexth row of the Pascal's triangle.


Notice that the row index starts from 0.

题意


给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。
在杨辉三角中,每个数是它左上方和右上方的数的和。

样例

示例:

输入: 3
输出: [1,3,3,1]


解题

https://blog.csdn.net/bojiujiu/article/details/80294803
思路是在O(k)的空间复杂度的限制下,在长度为k的数组内部,从杨辉三角的第一行开始依次计算到第k行的最终结果。
代码中i的值是第k行,j是第j个数。j从i开始,是因为第i行共有i+1个数字,从后往前计算,避免了第i-1行计算结果被覆盖丢失。
主要需要理解的是杨辉三角可以看成是一行行的数组
  1. 1

  2. 1 1

  3. 1 2 1

  4. 1 3 3 1

  5. 1 4 6 4 1

每一个数组都比上一个数组多一个数,第一位和最后一位都是1, 其余数字都是上一个数组对应位置和前一位置的数字的和 a[i][j] = a[i-1][j] + a[i-1][j-1]


class Solution {
    public List getRow(int rowIndex) {
        Integer[] result = new Integer[rowIndex+1];
        Arrays.fill(result, 0);
        result[0] = 1;
        for(int i = 1; i            for(int j=i;j>0;j--) {
                result[j] = result[j] + result[j-1];
            }
        }
        return Arrays.asList(result);
    }
}



好了,今天的文章就到这里,如果觉得有所收获,请顺手点个在看或者转发吧,你们的支持是我最大的动力。

上期推文:

LeetCode1-100题汇总,希望对你有点帮助!
LeetCode刷题实战101:对称二叉树
LeetCode刷题实战102:二叉树的层序遍历
LeetCode刷题实战103:二叉树的锯齿形层次遍历
LeetCode刷题实战104:二叉树的最大深度
LeetCode刷题实战105:从前序与中序遍历序列构造二叉树
LeetCode刷题实战106:从中序与后序遍历序列构造二叉树
LeetCode刷题实战107:二叉树的层次遍历 II
LeetCode刷题实战108:将有序数组转换为二叉搜索树
LeetCode刷题实战109:有序链表转换二叉搜索树
LeetCode刷题实战110:平衡二叉树
LeetCode刷题实战111:二叉树的最小深度
LeetCode刷题实战112:路径总和

LeetCode刷题实战113:路径总和 II

LeetCode刷题实战114:二叉树展开为链表

LeetCode刷题实战115:不同的子序列

LeetCode刷题实战116:填充每个节点的下一个右侧节点指针

LeetCode刷题实战117:填充每个节点的下一个右侧节点指针 II

LeetCode刷题实战118:杨辉三角


浏览 18
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报