算法修炼-动态规划之斐波那契数列模型

2024-03-01 06:04

本文主要是介绍算法修炼-动态规划之斐波那契数列模型,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、动态规划的算法原理

        这是本人动态规划的第一篇文章,所以先阐述一下动态规划的算法原理以及做题步骤。动态规划本人的理解就是通过题目所给的条件正确地填满dp表(一段数组)。首先要先确定好dp表每个位置的值所代表的含义是什么,然后通过题目条件以及经验推出状态转移方程,第三个就是初始化,确定填表顺序以及保证填表不越界,最后输出题目所需的结果,大致就是这个思路。

二、斐波那契数列模型例题分析

1137. 第 N 个泰波那契数 - 力扣(LeetCode)

本题的思路较为简单,状态转移方程已经给出,直接上代码:

class Solution {
public:int tribonacci(int n) {vector<int> v1(n+1);//初始化if(n == 1)return 1;else if(n == 2)return 1;else if(n == 0)return 0;v1[0] = 0;v1[1] = 1;v1[2] = 1;for(int i = 3; i <= n; i++){v1[i] = v1[i-1] + v1[i-2] + v1[i-3];}return v1[n];}
};

面试题 08.01. 三步问题 - 力扣(LeetCode)

解析: 

        假设小孩此时正处于某一台阶上,那他是如何到达这一台阶的呢?是不是他有可能是从该台阶的前一个台阶跳上来的,也可能是从该台阶的前两个台阶跳上来的,也可能是从该台阶的前三个台阶跳上来的,所以小孩到某一台阶就有三种可能情况,也即dp表中某个位置的值就是这个位置前三个位置的值相加,从而确定出了状态转移方程。

class Solution {
public:int waysToStep(int n) {//创建dp表vector<int> v1(n+1);if(n ==1)return 1;if(n == 2)return 2;if(n == 3)return 4;//初始化v1[1] = 1;v1[2] = 2; v1[3] = 4;for(int i = 4; i <= n; i++){//确定状态转移方程,这里需要注意,加数的和可能会越界,根据题目要求要对1000000007取模v1[i] = ((v1[i-1] + v1[i-2]) % 1000000007 + v1[i-3])%1000000007;} return v1[n];}
};

 746. 使用最小花费爬楼梯 - 力扣(LeetCode)

解析: 

        要确定每一级楼梯最低花费,通过比较前两级楼梯,确定应该加的值,从而确定状态转移方程。

class Solution {
public:int minCostClimbingStairs(vector<int>& cost) {int length = cost.size();//dp表vector<int> MinCost(length);//初始化for(int i = 0; i<cost.size(); i++){MinCost[i] = cost[i];}//状态转移方程for(int i = 2; i<length; i++){if(MinCost[i-1] < MinCost[i-2]){MinCost[i] += MinCost[i-1];}else{MinCost[i] += MinCost[i-2];}}if(MinCost[cost.size() - 1] < MinCost[cost.size() - 2]){return MinCost[cost.size() - 1];}else{return MinCost[cost.size() - 2];}}
};

 91. 解码方法 - 力扣(LeetCode)

解析: 

        选定一个位置作为结尾,如果这个位置的值不为零,就看其能否与前一个位置的值组成合法编码,如果能,这个位置的值就是它的前一个位置加上它的前前一个位置的值,如果不能,这个位置的值就是它的前一个位置的值;如果这个位置的值为零,就看其能否与前一个位置的值组成合法编码,如果能,这个位置的值就是它的前前一个位置的值。

class Solution {
public:int numDecodings(string s) {int len = s.length();int arr[len];const char* str;str = s.c_str();for(int i = 0; i<len; i++){arr[i] = str[i] - 48;}//处理特殊情况if(arr[0] == 0){return 0;}else if(len == 1 && arr[0] != 0){return 1;}for(int i = 1; i<len; i++){//例:30if(arr[i] == 0 && (arr[i-1] >2)){return 0;}//例:1001else if(i+1 < len && arr[i] == 0 && arr[i+1] == 0){return 0;}}for(int i = 0; i<len; i++){cout << arr[i] << " ";}//dp表vector<int> vect(len+1);//初始化vect[0] = 1;vect[1] = 1;//状态转移方程for(int i = 2; i < vect.size(); i++){if(arr[i-1] != 0){if(arr[i-2] != 0 && ((arr[i-1] + arr[i-2]*10) <= 26)){vect[i] = vect[i-1] + vect[i-2];}else{vect[i] = vect[i-1];}}else{vect[i] = vect[i-2];}}return vect[len];}
};

这篇关于算法修炼-动态规划之斐波那契数列模型的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Spring Security基于数据库的ABAC属性权限模型实战开发教程

《SpringSecurity基于数据库的ABAC属性权限模型实战开发教程》:本文主要介绍SpringSecurity基于数据库的ABAC属性权限模型实战开发教程,本文给大家介绍的非常详细,对大... 目录1. 前言2. 权限决策依据RBACABAC综合对比3. 数据库表结构说明4. 实战开始5. MyBA

Java调用C++动态库超详细步骤讲解(附源码)

《Java调用C++动态库超详细步骤讲解(附源码)》C语言因其高效和接近硬件的特性,时常会被用在性能要求较高或者需要直接操作硬件的场合,:本文主要介绍Java调用C++动态库的相关资料,文中通过代... 目录一、直接调用C++库第一步:动态库生成(vs2017+qt5.12.10)第二步:Java调用C++

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

C#如何动态创建Label,及动态label事件

《C#如何动态创建Label,及动态label事件》:本文主要介绍C#如何动态创建Label,及动态label事件,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#如何动态创建Label,及动态label事件第一点:switch中的生成我们的label事件接着,

SpringCloud动态配置注解@RefreshScope与@Component的深度解析

《SpringCloud动态配置注解@RefreshScope与@Component的深度解析》在现代微服务架构中,动态配置管理是一个关键需求,本文将为大家介绍SpringCloud中相关的注解@Re... 目录引言1. @RefreshScope 的作用与原理1.1 什么是 @RefreshScope1.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Java的IO模型、Netty原理解析

《Java的IO模型、Netty原理解析》Java的I/O是以流的方式进行数据输入输出的,Java的类库涉及很多领域的IO内容:标准的输入输出,文件的操作、网络上的数据传输流、字符串流、对象流等,这篇... 目录1.什么是IO2.同步与异步、阻塞与非阻塞3.三种IO模型BIO(blocking I/O)NI

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

基于Flask框架添加多个AI模型的API并进行交互

《基于Flask框架添加多个AI模型的API并进行交互》:本文主要介绍如何基于Flask框架开发AI模型API管理系统,允许用户添加、删除不同AI模型的API密钥,感兴趣的可以了解下... 目录1. 概述2. 后端代码说明2.1 依赖库导入2.2 应用初始化2.3 API 存储字典2.4 路由函数2.5 应

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时