class Solution {
public List<List<Integer>> generate(int numRows) {
List<List<Integer>> triangle = new ArrayList<List<Integer>>();
// First base case; if user requests zero rows, they get zero rows.
if (numRows == 0) {
return triangle;
}
// Second base case; first row is always [1].
triangle.add(new ArrayList<>());
triangle.get(0).add(1);
for (int rowNum = 1; rowNum < numRows; rowNum++) {
List<Integer> row = new ArrayList<>();
List<Integer> prevRow = triangle.get(rowNum-1);
// The first row element is always 1.
row.add(1);
// Each triangle element (other than the first and last of each row)
// is equal to the sum of the elements above-and-to-the-left and
// above-and-to-the-right.
for (int j = 1; j < rowNum; j++) {
row.add(prevRow.get(j-1) + prevRow.get(j));
}
// The last row element is always 1.
row.add(1);
triangle.add(row);
}
要明确几件事情:
1.每一行开头和结尾元素的值为1,要添加元素的个数和所在行有关。从每行的‘1’位置元素到行数的前一个元素。
2.要保留当前行前一行的值,当前行某一位置的值,等于前一行该位置和前一行该位置的上一位置的值相加。
3.使用两个for循环。第二个for循环的值截止值与当前行数有关。
return triangle;
}
}
杨辉三角
最新推荐文章于 2021-01-23 09:10:20 发布