给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。
在杨辉三角中,每个数是它左上方和右上方的数的和。
示例:
解题思路:将三角形边缘全都设为1,剩下的位置取左上和右上数字的和
时间复杂度:O(N^2)
空间复杂度:O(1)
class Solution {
public List<List<Integer>> generate(int numRows) {
List<List<Integer>> list = new ArrayList<>();
for(int i = 0; i < numRows; i++){
List<Integer> row = new ArrayList<>();
for(int j = 0; j <= i; j++){
if(j == 0 || j == i){
row.add(1);
}
else{
row.add(list.get(i-1).get(j-1) + list.get(i-1).get(j));
}
}
list.add(row);
}
return list;
}
}
版权声明:本文为weixin_49131718原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。