目录
题目详情
给定一个非负整数 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 <= numRows <= 30
结构
-
第 nn 行有 nn 个数(从第 1 行开始计)。
-
每个数是它左上方和右上方的数的和(在三角中表现为正上方和左上方的和)。
-
通常第一行是 11(第 0 行有时也记为 11)。
题解:
java
import java.util.ArrayList;
import java.util.List;
/**
* 力扣,118. 杨辉三角
*/
public class main2 {
public static void main(String[] args) {
int n=5;
List<List<Integer>> generate = generate(n);
return;
}
public static List<List<Integer>> generate(int numRows) {
List<List<Integer>> result = new ArrayList<>();
List<Integer> shang=null;
for (int i = 1; i <= numRows; i++) {
List<Integer> integers = new ArrayList<>();
for (int j = 0; j < i; j++) {
if(j==0 || j==i-1) {
integers.add(1);
continue;
}
integers.add(shang.get(j-1)+shang.get(j));
}
shang=integers;
result.add(integers);
}
return result;
}
}