1. 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>> results;
vector<int> newlevel;
int i=0;
while(i<numRows)
{
if(i==0)
{
newlevel.push_back(1);
results.push_back(newlevel);
newlevel.clear();
}
else{
for(int j=0; j<=results.at(i-1).size();j++)
{
if(j==0 )
{
newlevel.push_back(results.at(i-1).at(j));
}
else if(j==results.at(i-1).size())
{
newlevel.push_back(results.at(i-1).at(j-1));
}
else{
int val=results.at(i-1).at(j-1)+results.at(i-1).at(j);
newlevel.push_back(val);
}
}
results.push_back(newlevel);
newlevel.clear();
}
i++;
}
return results;
}
};
2.
Given an index k, return the kth row of the Pascal's triangle.
For example, given k = 3,
Return [1,3,3,1]
.
class Solution {
public:
vector<int> getRow(int rowIndex) {
// Start typing your C/C++ solution below
// DO NOT write int main() function
vector<int> result;
int i=0;
for(int i=0;i<=rowIndex;i++)
{
if(i==0)
{
result.push_back(1);
}
else{
int size=result.size();
for(int j=size;j>0;j--)
{
if(j==size)
{
result.push_back(result.at(size-1));
}
else
{
result[j]=result[j]+result[j-1];
}
}
}
}
return result;
}
};