前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >算法简单题,吾辈重拳出击 - 第 N 个泰波那契数

算法简单题,吾辈重拳出击 - 第 N 个泰波那契数

作者头像
掘金安东尼
发布2022-08-22 09:19:45
2090
发布2022-08-22 09:19:45
举报
文章被收录于专栏:掘金安东尼

听说过斐波那契数列,那你听说过泰波那契数列吗?

上题!

泰波那契序列 Tn 定义如下:  T0 = 0, T1 = 1, T2 = 1, 且在 n >= 0 的条件下 Tn+3 = Tn + Tn+1 + Tn+2 给你整数 n,请返回第 n 个泰波那契数 Tn 的值。

示例 1:

代码语言:javascript
复制
输入:n = 4
输出:4
解释:
T_3 = 0 + 1 + 1 = 2
T_4 = 1 + 1 + 2 = 4

示例 2:

代码语言:javascript
复制
输入:n = 25
输出:1389537

提示:

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

第一反应

斐波那契是 T(n) = T(n-1) + T(n-2)

泰波那契是 T(n) = T(n-1) + T(n-2) + T(n-3)

那求和也简单鸭,第一个数是 0,第二个数是 1,第三个数是 2

代码语言:javascript
复制
var tribonacci = function(n) {
    let x = 0
    let y = 1
    let z = 1
    let res = 0
    if(n<2) return n
    if(n==2) return 1
    for(let i=3;i<=n;i++){
        res = x+y+z
        x = y
        y = z
        z = res
    }
    return res
};

第二反应

递归求解

代码语言:javascript
复制
var tribonacci = function(n) {
    let x = 0
    let y = 1
    let z = 1
    if(n<2) return n
    if(n==2) return 1
    let res =  tribonacci(n-1) + tribonacci(n-2) + tribonacci(n-3)
    return res
};
image.png
image.png

运行时间超出内存,递归时间复杂度 O(3n)

小结:

本题关键在于认识下泰波那契数,有概念即可~~

是不是对于斐波那契、爬楼梯这样的题目得心应手了呢?(●'◡'●)

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-08-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

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

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

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