题目:
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,然后从前面一排的数据中加即可。。。。
代码:
class Solution {
public:
vector<vector<int>> generate(int numRows) {
vector<vector<int>> res;
vector<int>pre,now;
if(numRows>0){
for(int row=1;row<=numRows;++row){
now.insert(now.begin(),1);
if(row!=1)
now.insert(now.end(),1);
for(int count=1;count<row-1;++count){
int elem=pre[count-1]+pre[count];
now.insert(now.end()-1,elem);
}
res.insert(res.end(),now);
pre=now;
now.erase(now.begin(),now.end());
}
}
return res;
}
};