C++实现泰波那契数

C++实现泰波那契数

问题描述
泰波那契序列 Tn 定义如下:
T0 = 0, T1 = 1, T2 = 1, 且在 n >= 0 的条件下 Tn+3 = Tn + Tn+1 + Tn+2
给整数 n,请返回第 n 个泰波那契数 Tn 的值。
链接:https://leetcode-cn.com/problems/n-th-tribonacci-number
一开始我还是用的和写斐波那契数列一样的方法

class Solution {
public:
    int tribonacci(int n) 
    {
        if(n==0||n==1)
        {
            return n;
        }
        else if(n==2)
        {
            return 1;
        }
        else
        {
            return tribonacci(n-1)+tribonacci(n-2)+tribonacci(n-3);
        }

    }
};

但是在提交时显示“超出时间限制”,之后参考了评论里题友的回答

实在是雪中送炭在这里插入图片描述
之后根据他的代码进行了改进

class Solution {
public:
    long int tribonacci(int n) 
    {
        switch(n)
       { 
        case 0:
            return 0;
        case 1:
            return 1;
        case 2:
            return 1;
        case 3:
            return 2;
        case 4:
            return 4;
        default:
            return 2*tribonacci(n-1)-tribonacci(n-4);

       }
    }

这里在定义函数的时候返回值数据类型是long int 型,是因为int型的数据范围比较小,在n为25时,它的泰波那契数为1389537。在之后提交时出现错误,才定义为 long int 型。

如果有更好的方法可以私信我一起交流。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值