给定一个非负整数 numRows,生成杨辉三角的前 numRows 行。
在杨辉三角中,每个数是它左上方和右上方的数的和。
示例:
输入: 5
输出:
[
[1],
[1,1],
[1,2,1],
[1,3,3,1],
[1,4,6,4,1]
]
class Solution {
public:
vector<vector<int>> generate(int numRows) {
if(numRows==0) return {};
vector<int> temp;
vector<int> temp1;
vector<vector<int>> result;
for(int i=0; i<numRows; i++)
{
temp.push_back(1);
temp1 = temp;
for(int j=1; j<temp.size()-1; j++)
{
temp[j] = temp1[j-1] + temp1[j];
}
result.push_back(temp);
}
return result;
}
};
代码改进:
class Solution {
public:
vector<vector<int>> generate(int numRows) {
vector<vector<int>> result;
for(int i=0; i<numRows; i++)
{
if(i==0)
result.push_back({1});
else
{
result.push_back(result[i-1]);
result[i].push_back(1);
for(int j=1; j<i; j++)
{
result[i][j] = result[i-1][j-1] + result[i-1][j];
}
}
}
return result;
}
};