动态规划 - 1137.第N个泰波那契数(C#和C实现)

2023-12-19 22:04

本文主要是介绍动态规划 - 1137.第N个泰波那契数(C#和C实现),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

动态规划 - 1137.第N个泰波那契数(C#和C实现)

题目描述

泰波那契序列 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 位整数,即 0 <= answer <= 2^31 - 1

解题思路

动态规划
  1. 定义状态:dp[i] 表示泰波那契数列的第 i 项。
  2. 状态转移方程: dp[i] = dp[i-3] + dp[i-2] + dp[i-1],即第 i 项等于第 i-3i-2i-1 项的和。
  3. 初始状态: dp[0] = 0dp[1] = 1dp[2] = 1
  4. 遍历顺序: 从小到大遍历,计算每一项的值。
特殊案例
  • 如果输入 n 为 0、1 或 2,则直接返回 n

C#代码实现

public int Tribonacci(int n) {if (n == 0) {return 0;}// 如果n等于1或者2,返回1if (n == 1 || n == 2) {return 1;}// 创建一个长度为n+1的数组dpint[] dp = new int[n + 1];// dp[0]初始化为0dp[0] = 0;// dp[1]初始化为1dp[1] = 1;// dp[2]初始化为1dp[2] = 1;// 从3开始,到n结束for (int i = 3; i <= n; i++) {// dp[i]等于dp[i - 3] + dp[i - 2] + dp[i - 1]dp[i] = dp[i - 3] + dp[i - 2] + dp[i - 1];}// 返回dp[n]return dp[n];
}

C代码实现

int tribonacci(int n) {// 如果n等于0,返回0if (n == 0) {return 0;}// 如果n等于1或者2,返回1if (n == 1 || n == 2) {return 1;}// 定义一个数组,长度为n+1int* dp = (int*)malloc(sizeof(int) * (n + 1));// 初始化数组,dp[0] = 0,dp[1] = 1,dp[2] = 1dp[0] = 0;dp[1] = 1;dp[2] = 1;// 从3开始,到n结束for (int i = 3; i <= n; i++) {// 状态转移方程:dp[i] = dp[i - 3] + dp[i - 2] + dp[i - 1]dp[i] = dp[i - 3] + dp[i - 2] + dp[i - 1];}// 记录结果int result = dp[n];// 释放内存free(dp);// 返回结果return result;
}

时间复杂度和空间复杂度

  • 时间复杂度:O(n),其中 n 是泰波那契数列的项数。需要计算每一项的值。
  • 空间复杂度:O(n)。使用了一个大小为 n+1 的数组来保存中间结果。

参与点评

读者朋友们,如果您在阅读过程中,对文章的质量、易理解性有任何建议,欢迎在评论区指出,我会认真改进。

这篇关于动态规划 - 1137.第N个泰波那契数(C#和C实现)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

Java HashMap的底层实现原理深度解析

《JavaHashMap的底层实现原理深度解析》HashMap基于数组+链表+红黑树结构,通过哈希算法和扩容机制优化性能,负载因子与树化阈值平衡效率,是Java开发必备的高效数据结构,本文给大家介绍... 目录一、概述:HashMap的宏观结构二、核心数据结构解析1. 数组(桶数组)2. 链表节点(Node

Java AOP面向切面编程的概念和实现方式

《JavaAOP面向切面编程的概念和实现方式》AOP是面向切面编程,通过动态代理将横切关注点(如日志、事务)与核心业务逻辑分离,提升代码复用性和可维护性,本文给大家介绍JavaAOP面向切面编程的概... 目录一、AOP 是什么?二、AOP 的核心概念与实现方式核心概念实现方式三、Spring AOP 的关

一文解析C#中的StringSplitOptions枚举

《一文解析C#中的StringSplitOptions枚举》StringSplitOptions是C#中的一个枚举类型,用于控制string.Split()方法分割字符串时的行为,核心作用是处理分割后... 目录C#的StringSplitOptions枚举1.StringSplitOptions枚举的常用

Python实现字典转字符串的五种方法

《Python实现字典转字符串的五种方法》本文介绍了在Python中如何将字典数据结构转换为字符串格式的多种方法,首先可以通过内置的str()函数进行简单转换;其次利用ison.dumps()函数能够... 目录1、使用json模块的dumps方法:2、使用str方法:3、使用循环和字符串拼接:4、使用字符

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

Linux挂载linux/Windows共享目录实现方式

《Linux挂载linux/Windows共享目录实现方式》:本文主要介绍Linux挂载linux/Windows共享目录实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录文件共享协议linux环境作为服务端(NFS)在服务器端安装 NFS创建要共享的目录修改 NFS 配

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter