跳转至

119.杨辉三角 II

题目描述

原题

给定一个非负索引k,其中 k ≤ 33,返回杨辉三角的第 k 行。

在杨辉三角中,每个数是它左上方和右上方的数的和。

示例:

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

进阶:

你可以优化你的算法到 O\(k\) 空间复杂度吗?

题解

class Solution {
    public List<Integer> getRow(int rowIndex) {
        int[][] arry = new int[rowIndex+1][rowIndex+1];
        List<Integer> list = new ArrayList<>();
        for (int i = 0; i <= rowIndex; i++) {
            arry[i][0] = 1;
            if(rowIndex==i) {
                list.add(arry[i][0]);
            }
            for (int j = 1; j <= i; j++) {
                arry[i][j] = arry[i - 1][j - 1] + arry[i - 1][j];
                if(rowIndex==i) {
                    list.add(arry[i][j]);
                }

            }
        }
        return list;
    }
}