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] ]
class Solution {
public:
vector<vector<int> > generate(int numRows) {
// Start typing your C/C++ solution below
// DO NOT write int main() function
vector<vector<int> > result;
if (numRows == 0) {
return result;
}
vector<int> line;
line.push_back(1);
result.push_back(line);
if (numRows == 1) {
return result;
}
int line_cnt = 1;
vector<int> pre_line = line;
line.clear();
while (line_cnt < numRows) {
for (int i = 0; i <= line_cnt; ++i) {
if (i == 0) {
line.push_back(pre_line[i]);
} else if (i == line_cnt) {
line.push_back(pre_line[i -1]);
} else {
line.push_back(pre_line[i] + pre_line[i-1]);
}
}
result.push_back(line);
pre_line = line;
line.clear();
++line_cnt;
}
return result;
}
};