题目描述
题目来源于leetcode
给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。
在杨辉三角中,每个数是它左上方和右上方的数的和。
示例:
输入: 5
输出:
[
[1],
[1,1],
[1,2,1],
[1,3,3,1],
[1,4,6,4,1]
]
简单分析
可以用递归来完成此题,
第一行是特殊的,只有1个元素1
从第二行开始,它的元素都是第一个是1,中间是上一行的第0,1元素之和、
第1,2元素之和、第2,3元素之和…第n,n+1元素之和,n+1<上一层元素的个数,末尾元素也是1
代码
class Solution {
public List<List<Integer>> generate(int numRows) {
List<List<Integer>> list = new LinkedList<>();
List<Integer> list2 = new LinkedList<>();
action(list,list2,1,numRows);//从第一行开始
return list;
}
private void action(List<List<Integer>> list, List<Integer> list2, int i, int numRows) {
if(i>numRows) {
return;
}
if(i==1) {//实现第一行
List<Integer> l = new LinkedList<>();
l.add(1);
list.add(l);
action(list, l, i+1, numRows);
}
if(i>1) {
List<Integer> l = new LinkedList<>();
l.add(1);
for(int m=0;m+1<i-1;m++) {//m+1要小于上一行的最后一个元素的下标
l.add(list2.get(m)+list2.get(m+1));
}
l.add(1);
list.add(l);
action(list, l, i+1, numRows);
}
}
}