给定一个非负整数numRows,生成「杨辉三角」的前numRows行。在「杨辉三角」中,每个数是它左上方和右上方的数的和。
示例 1:
输入:numRows = 5
输出:[[1],[1,1],[1,2,1],[1,3,3,1],[1,4,6,4,1]]
示例 2:
输入:numRows = 1
输出:[[1]]
思路:根据图观察规律
public List<List<Integer>> generate(int numRows) { List<List<Integer>> generate = new ArrayList<>(); for(int i = 0; i < numRows; i++){ List<Integer> list = new ArrayList<>(); if(i == 0){ list.add(1); generate.add(list); continue; } for(int j = 0; j <= i; j++){ if(j == 0 || j == i){ list.add(1); } else{ list.add(generate.get(i - 1).get(j - 1) + generate.get(i - 1).get(j)); } } generate.add(list); } return generate; }