解决斐波那契数列 (2) 第 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。

链接:https://leetcode-cn.com/problems/n-th-tribonacci-number

这道例题我在做的时候,就用了之前的数组填充法,变量迭代法会更加繁琐。当然这种的问题重要的是边界条件。为此我特意将各个可能出现的边界条件利用“if-else”进行区别,下面是我的源代码:

int tribonacci(int n){
int arr[n+1];
int a;
if(n==0){
    return 0;
}
else if(n==1){
    return 1;
}
else if(n==2){
    return 1;
}
else{
arr[0]=0;
arr[1]=1;
arr[2]=1;
int i;
for(i = 3;i<n+1;i++){
    arr[i] = arr[i-1]+arr[i-2]+arr[i-3];
}
a = arr[n];
return a;
}
}

作者:zzz-253
链接:https://leetcode-cn.com/problems/n-th-tribonacci-number/solution/di-n-ge-tai-bo-na-qi-shu-by-zzz-253/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

你可能感兴趣的:(斐波那契数列)