【题目描述】
Given numRows, generate the first numRows of Pascal's triangle.
For example, given numRows = 5,
Return
[ [1], [1,1], [1,2,1], [1,3,3,1], [1,4,6,4,1] ]【思路】
有两种思路:
思路1:
下一行的值首尾为1 ,从第二个开始等于前一行左右两值相加之和。
思路2:
从右往左看,下一行的数等于上一行左上角和右上角的和。
【代码】
思路1:
class Solution {
public:
vector<vector<int>> generate(int numRows) {
vector<vector<int>> result;
if(numRows==0) return result;
result.push_back(vector<int>(1,1));
for(int i=2;i<=numRows;i++){
vector<int> current(i,1);
vector<int> pre=result[i-2];
for(int j=1;j<pre.size();j++){
current[j]=pre[j-1]+pre[j];
}
result.push_back(current);
}
return result;
}
};
class Solution {
public:
vector<vector<int>> generate(int numRows) {
vector<vector<int>> result;
vector<int> array(1,1);
if(numRows==0) return result;
result.push_back(array);
for(int i=2;i<=numRows;i++){
for(int j=i-2;j>0;j--){
array[j]=array[j]+array[j-1];
}
array.push_back(1);
result.push_back(array);
}
return result;
}
};