「LeetCode」递归题目之第N个Tribonacci数

2024-06-23 20:18

本文主要是介绍「LeetCode」递归题目之第N个Tribonacci数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Tribonacci序列Tn定义:

T0=0, T1=1, T2=1, n>=0时,Tn 3 = Tn Tn 1 Tn 2

限制条件是: 0<=n<=37, 32位整型。

我直接用C 撸了下面的代码,

#include <iostream>using namespace std;class Solution {
public:int tribonacci(int n) {if (n ==  2){return 1;} if (n == 1){return 1;} if (n == 0){return 0;} int result = tribonacci(n-3)   tribonacci(n-2)   tribonacci(n-1);return result;}
};// 下面是自己电脑编译测试用的代码
int main(){Solution sol;for (int i = 0; i <= 37; i  ){cout << "tribonacci " << i << " is " << sol.tribonacci(i) << endl;}}

提交答案后,提示"The Limit Exceeded".

在自己服务器测试时,也发现当n=31之后的速度下降的非常快。

# 编译
g   -o trib trib.cpp
./trib

原因是当n越大时,直接使用递归会产生大量的重复计算,导致计算效率下降。为了解决该问题,需要维护一个已计算结果的字典,避免重复运算。

#include <iostream>using namespace std;class Solution {
public:int tribo[100];int tribonacci(int n) {if (n ==  2){return 1;} if (n == 1){return 1;} if (n == 0){return 0;} if (tribo[n] > 0){return tribo[n]-1;}int result = tribonacci(n-3)   tribonacci(n-2)   tribonacci(n-1);tribo[n] = result   1;return result;}
};// 下面是自己电脑编译测试用的代码
int main(){Solution sol;for (int i = 0; i <= 37; i  ){cout << "tribonacci " << i << " is " << sol.tribonacci(i) << endl;}}

新的代码中,我预先定义了一个大小为100的数组,主要是因为题目限制n的取值,如果n没有限制取值,我会考虑使用vector容器或者map词典。其次考虑到n=0时,结果为0,并且数组初始化值为0,为了能够通过数组值是否为0来判断是否已经计算了相应的tribonacci值,我对结果加上了一个pseducount。

最后这段代码运行速度是0ms.

如果要用哈希字典,代码如下

#include <map>
//一定要引入map头文件
class Solution {
public://定义一个哈希字典map<int, int> num;int tribonacci(int n) {if(n < 2) return n;if(n == 2) return 1;//如果字典中有已经计算的结果,直接返回结果if(num.find(n) != num.end()) return num[n];int sum = tribonacci(n-1)   tribonacci(n-2)   tribonacci(n-3);num[n] = sum;return sum;}
};

版权声明:本博客所有文章除特别声明外,均采用 知识共享署名-非商业性使用-禁止演绎 4.0 国际许可协议 (CC BY-NC-ND 4.0) 进行许可。

扫码即刻交流

这篇关于「LeetCode」递归题目之第N个Tribonacci数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1088173

相关文章

哈希leetcode-1

目录 1前言 2.例题  2.1两数之和 2.2判断是否互为字符重排 2.3存在重复元素1 2.4存在重复元素2 2.5字母异位词分组 1前言 哈希表主要是适合于快速查找某个元素(O(1)) 当我们要频繁的查找某个元素,第一哈希表O(1),第二,二分O(log n) 一般可以分为语言自带的容器哈希和用数组模拟的简易哈希。 最简单的比如数组模拟字符存储,只要开26个c

leetcode-24Swap Nodes in Pairs

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode swapPairs(L

leetcode-23Merge k Sorted Lists

带头结点。 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode(int x) { val = x; }* }*/public class Solution {public ListNode mergeKLists

题目1254:N皇后问题

题目1254:N皇后问题 时间限制:1 秒 内存限制:128 兆 特殊判题:否 题目描述: N皇后问题,即在N*N的方格棋盘内放置了N个皇后,使得它们不相互攻击(即任意2个皇后不允许处在同一排,同一列,也不允许处在同一斜线上。因为皇后可以直走,横走和斜走如下图)。 你的任务是,对于给定的N,求出有多少种合法的放置方法。输出N皇后问题所有不同的摆放情况个数。 输入

题目1380:lucky number

题目1380:lucky number 时间限制:3 秒 内存限制:3 兆 特殊判题:否 提交:2839 解决:300 题目描述: 每个人有自己的lucky number,小A也一样。不过他的lucky number定义不一样。他认为一个序列中某些数出现的次数为n的话,都是他的lucky number。但是,现在这个序列很大,他无法快速找到所有lucky number。既然

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

【JavaScript】LeetCode:16-20

文章目录 16 无重复字符的最长字串17 找到字符串中所有字母异位词18 和为K的子数组19 滑动窗口最大值20 最小覆盖字串 16 无重复字符的最长字串 滑动窗口 + 哈希表这里用哈希集合Set()实现。左指针i,右指针j,从头遍历数组,若j指针指向的元素不在set中,则加入该元素,否则更新结果res,删除集合中i指针指向的元素,进入下一轮循环。 /*** @param

【408数据结构】散列 (哈希)知识点集合复习考点题目

苏泽  “弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家    知识点 1. 散列查找 散列查找是一种高效的查找方法,它通过散列函数将关键字映射到数组的一个位置,从而实现快速查找。这种方法的时间复杂度平均为(