第 N 个泰波那契数(C++)

65 阅读1分钟

第 N 个泰波那契数

泰波那契序列 Tn 定义如下:

T0 = 0, T1 = 1, T2 = 1, 且在 n >= 0 的条件下 Tn+3 = Tn + Tn+1 + Tn+2

给你整数 n,请返回第 n 个泰波那契数 Tn 的值。

示例 1:

输入:n = 4
输出:4
解释:
T_3 = 0 + 1 + 1 = 2
T_4 = 1 + 1 + 2 = 4

示例 2:

输入:n = 25
输出:1389537

提示:

  • 0 <= n <= 37
  • 答案保证是一个 32 位整数,即 answer <= 2^31 - 1

我的代码:

class Solution {
    // 其实就是斐波拉契数列的升级版
public:
    int tribonacci(int n) {
        if (n == 0) return 0;
        if (n <= 2) return 1;
        int p = 0, q = 0, r = 1, s = 1;
        for (int i = 3; i <= n; ++ i)
        {
            p = q;
            q = r;
            r = s;
            s = p + q + r;
        }
        return s;
    }
};

对应我的csdn文章:(2条消息) 第 N 个泰波那契数(C++)_极客李华的博客-CSDN博客