前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >杨辉三角 II(leetcode.119)

杨辉三角 II(leetcode.119)

原创
作者头像
euclid
修改2020-01-06 11:00:14
3460
修改2020-01-06 11:00:14
举报
文章被收录于专栏:Euclid学习日记

1.数学方法

图片来自互联网
图片来自互联网

我们只需计算所求行的值就可以了

Cnk​=n!/(k!(n−k)!)=(n∗(n−1)∗(n−2)∗...(n−k+1))/k!

代码语言:c++
复制
class Solution {
public:
    vector<int> getRow(int rowIndex) {
        vector<int> result;
        for(int i = 0;i <= rowIndex;i++){
            result.push_back(C(rowIndex, i));
        }
        return result;
    }
    int C(int n, int k){
        long res = 1;
        for(int i = 1;i <= k;i++){
            res = res * (n - k + i)/i; 
        }
        return (int)res;
    }
};

2.常规方法

因为只需要返回第k行的数组,所以只需要两个数组pre和res;

代码语言:javascript
复制
class Solution {
public:
    vector<int> getRow(int rowIndex) {
        vector<int> pre;
        vector<int> res;
        for(int i = 0;i <= rowIndex;i++){
            res.clear();
            for(int j = 0;j <= i;j++){
                if(j == 0||j == i)
                    res.push_back(1);
                else
                    res.push_back(pre[j] + pre[j-1]);
            }
            pre = res;
        }
        return res;
    }
};

3.大佬的做法(✪ ω ✪)

膜拜~

可以看作是方法二的提升版本

代码语言:javascript
复制
class Solution {
public:
    vector<int> getRow(int rowIndex) {
        vector<int> result;
        for(int i = 0; i <= rowIndex; ++i){
            result.push_back(1);
            for(int j = i - 1; j > 0; --j){
                result[j] += result[j - 1];
            }
        }
        return result;
    }
};

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档