给定一个非负索引 k,其中 k ≤ 33,返回杨辉三角的第 k 行。
在杨辉三角中,每个数是它左上方和右上方的数的和。
示例:
输入: 3
输出: [1,3,3,1]
一、思路
C++代码
class Solution {
public:
vector<int> ans;
vector<int> getRow(int rowIndex) {
vector<int> row(1, 1);
rowIndex++;
generateRow(row, rowIndex);
return ans;
}
void generateRow(vector<int> row, int& rowIndex) {
if (row.size() == rowIndex) {
ans = row;
return;
}
vector<int> next_row;
next_row.push_back(1);
for (int i = 1; i < row.size(); i++) {
int temp = row[i - 1] + row[i];
next_row.push_back(temp);
}
next_row.push_back(1);
generateRow(next_row, rowIndex);
}
};