动态规划原理及算法题(1)

news2025/1/16 5:39:27

课程规划会分为四个阶段进行:

1.题目解析

2.讲解算法原理(动态规划的原理)

3.编写代码

4.空间优化

1. 第 N 个泰波那契数(easy)

泰波那契数相当于斐波那契数的孪生兄弟,是它的加强版。

1.题目解析

 2.讲解算法原理

如果用动态规划的原理来解决这个问题的话,一般分五步进行

(1) 确定状态表示

动态规划的做题流程一般是先定义一个dp表,dp表一般就是一个一维数组或者是一个二维数组

先定义一个数组,这个数组一般就叫做dp表,然后想办法把这个dp表填满,填满之后里面的某一个值可能就是我们的最终结果。

状态表示就是dp表中某一个值所代表的含义 

状态表示是怎么来的呢?

1,题目要求

2,经验 + 题目要求

3,分析问题的过程中,发现重复子问题,把重复子问题抽象成为状态表示

所以刚开始先练前两个,等到动态规划熟了,进而介绍第三种,第三种就是表示动态规划的方式。

(2)根据状态表示来推导状态转移方程

和(1)一样,不用学术型的语言来表示状态转移方程,我们这里的状态转移方程就是dp[i]等于什么。

(1)和(2)是动态规划中最核心的两步

(3)初始化

初始化的含义就是保证填表的时候不越界。

怎么填表?就是根据状态转移方程来进行填表。

(4)填表顺序

为什么要研究它呢?就是为了填写当前状态的时候,所需要的状态已经计算过了

(5)返回值

返回值就是最终我们想要的结果。结合题目要求 + 状态表示

3.编写代码

动态规划代码的编写是非常固定的四步

1,创建一个dp表

2,在正式的填表之前初始化

3,正式填表

4,确定返回值

因为有n个值,所以要创建一个n + 1的dp表,才能访问到第 n 个值,因为数组的下标是从0开始的。

 解题代码:

class Solution {

public:

    int tribonacci(int n) {

        //处理一下边界问题

        if (n == 0 || n == 1)

            return n;

        if (n == 2)

            return 1;

        vector<int> a(n + 1);

        a[0] = 0, a[1] = a[2] = 1;

        for (int i = 3; i <= n; i++)

            a[i] = a[i - 1] + a[i - 2] + a[i - 3];

        return a[n];

    }

}

4.空间优化 

关于动态规划空间的优化,一般都用滚动数组。

滚动数组一般用有限个变量来表示的。为了取名方便就给它们起名叫滚动数组。用滚动数组做优化的时候,一定要确定好顺序。 赋值操作一定要确保从前向后赋值。

//滚动数组的写法

class Solution {

public:

    int tribonacci(int n) {

        // 处理一下边界问题

        if (n == 0 || n == 1)

            return n;

        if (n == 2)

            return 1;

        int a = 0, b = 1, c = 1, d = 0;

        for (int i = 3; i <= n; i++) {

            d = a + b + c;

            a = b, b = c, c = d;

        }

        return d;

    }

};

2. 三步问题(easy)

1.题目解析

当小孩在第0格位置的时候,要去第一节台阶,只有1种走法,要想到第二节台阶,可以从第一节台阶走,去第一节的台阶有一种走法,从1到2有一种,也可以从0阶台阶直接到第二节这算一种走法,加起来有两种走法,到第三节的时候,可以从0到3,也可以从1到三,也可以2到3,再加上如何到1、2台阶的方法数,加起来有四种......

2.讲解算法原理

(1) 确定状态表示

dp[i]表示到达 i 位置时,一共有多少种方法。

(2)根据状态表示来推导状态转移方程

以 i 位置的状态,最近的一步来划分问题,dp[i]可以分为三种情况,要么从dp[i - 1]到达dp[i],要么从dp[i - 2]到达dp[i],要么从dp[i - 3]到达dp[i]。

那么状态转移方程就有了:dp[i] = dp[i - 1] + dp[i - 2] + dp[i - 3]

(3)初始化

dp[0] = 0,dp[1] = 1,dp[2] = 2,dp[3] = 4

(4)填表顺序

从左到右

(5)返回值

1,创建dp表

2,初始化

3,填表

4,确定返回值

//题解

class Solution {

public:

    int waysToStep(int n) {

        const int MOD = 1e9 + 7;

        if (n == 0 || n == 1 || n == 2)

            return n;

        if (n == 3)

            return 4;

        vector<int> dp(n + 1);

        dp[1] = 1, dp[2] = 2, dp[3] = 4;

        for (int i = 4; i <= n; i++) {

             //因为值很大,所以要对结果取模1e9 + 7

            dp[i] = ((dp[i - 1] + dp[i - 2]) % MOD + dp[i - 3]) % MOD;

        }

        return dp[n];

    }

};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2219147.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java中的一些名词概念

**函数式接口:** 概念&#xff1a;一个接口中的抽象方法只有一个&#xff0c;那么这个接口就是一个函数式接口。形参: 形参变量是**功能函数里的变量**&#xff0c;只有<u>在被调用的时候才分配内存单元</u>&#xff0c;<u>调用结束后立即释放</u>。…

Unity使用Git及GitHub进行项目管理

git: 工作区,暂存区(存放临时要存放的内容),代码仓库区1.初始化 git init 此时展开隐藏项目,会出现.git文件夹 2.减小项目体积 touch .gitignore命令 创建.gitignore文件夹 gitignore文件夹的内容 gitignore中添加一下内容 # This .gitignore file should be place…

Java项目-基于Springboot的应急救援物资管理系统项目(源码+说明).zip

作者&#xff1a;计算机学长阿伟 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、ElementUI等&#xff0c;“文末源码”。 开发运行环境 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringBoot、Vue、Mybaits Plus、ELementUI工具&#xff1a;IDEA/…

Ubuntu20.04编译安卓aosp 15源码编译到模拟器运行

背景&#xff1a; aosp15也开始悄悄在各个手机厂商开始酝酿了&#xff0c;感叹时间很快&#xff0c;今天也准备针对aosp15进行一下源码环境的搭建&#xff0c;整体aosp15的搭建和13/14其实没啥大的差别&#xff0c;只不过在lunch目标这个地方确实很大不同&#xff0c;还有就是…

HCIP-HarmonyOS Application Developer 习题(十四)

&#xff08;多选&#xff09;1、HarmonyOs为应用提供丰富的Al(Artificial Intelligence)能力&#xff0c;支持开箱即用。下列哪些是它拥有的AI能力? A、通用文字识别 B、词性标注 C、实体识别 D、语音播报 答案&#xff1a;ABCD 分析&#xff1a; AI能力简介二维码生成根据开…

工业级三防平板在工厂极端环境下保障稳定运行

在现代工业环境中&#xff0c;尤其是在工厂车间&#xff0c;设备和技术的稳定性直接关系到生产效率与产品质量。然而&#xff0c;极端的工作条件常常给电子设备的使用带来了不小的挑战。为此&#xff0c;市场上出现了一种专为工业应用设计大尺寸手持三防平板电脑。这种设备以其…

2024年十大前沿图像分割模型汇总:工作机制、优点和缺点介绍

《博主简介》 小伙伴们好&#xff0c;我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源&#xff0c;可关注公-仲-hao:【阿旭算法与机器学习】&#xff0c;共同学习交流~ &#x1f44d;感谢小伙伴们点赞、关注&#xff01; 《------往期经典推…

antd vue 输入框高亮设置关键字

<highlight-textareaplaceholder"请输入主诉"type"textarea"v-model"formModel.mainSuit":highlightKey"schema.componentProps.highlightKey"></highlight-textarea> 参考链接原生input&#xff0c;textarea demo地址 …

【前端】如何制作一个自己的网站(11)

接上文。 除了前面的颜色样式外&#xff0c;字体样式和文本样式也是网页设计中的重要组成部分。 合适的字体和文本排版&#xff0c;不仅可以使页面更加美观&#xff0c;也可以提升用户体验。接下来&#xff0c;我们先来看看CSS如何设置字体样式。 字体样式 同时设置了字体样…

经典算法整理(Go语言实现)

经典算法系列文章目录 提示&#xff1a;这里可以添加系列文章的所有文章的目录&#xff0c;目录需要自己手动添加 第一章 回溯算法 第二章 贪心算法 第三章 动态规划 第四章 单调栈 第五章 图论 提示&#xff1a;写完文章后&#xff0c;目录可以自动生成&#xff0c;如何生成可…

机器学习课程学习周报十七

机器学习课程学习周报十七 文章目录 机器学习课程学习周报十七摘要Abstract一、机器学习部分1. 变分推断/推理1.1 证据下界1.2 q ( z ) {q(z)} q(z)的选取 2. VAE2.1 Auto-Encoder的简单回顾2.2 为什么提出VAE2.3 VAE的数学原理 3. Diffusion Model的数学原理3.1 Training算法…

React(五) 受控组件和非受控组件; 获取表单元素的值。高阶组件(重点),Portals; Fragment组件;严格模式StrictMode

文章目录 一、受控组件1. 什么是受控组件2. 收集input框内容3. 收集checkBox的值4. 下拉框select总结 二、非受控组件三、高阶组件1. 高阶组件的概念 (回顾高阶函数)2. 高阶组件应用&#xff1a;注入props(1) 高阶组件给---函数式组件注入props(2) 高阶组件给---类组件注入prop…

开源的存储引擎--cantian

cantian 上次稼先社会活动之后&#xff0c;在北京签售的时候见到了三位参天的核心人物。我有感于他们的热情、务实和坦诚&#xff0c;我觉得还应该在深入的做一些事情。至少可以安装体验一下&#xff0c;做做推广。毕竟现在务实的产品不多了&#xff0c;很多都是浮躁的宣传。为…

从一个事故中理解 Redis(几乎)所有知识点

作者&#xff1a;看破 一、简单回顾 事故回溯总结一句话&#xff1a; &#xff08;1&#xff09;因为大 KEY 调用量&#xff0c;随着白天自然流量趋势增长而增长&#xff0c;最终在业务高峰最高点期占满带宽使用 100%。 &#xfeff; &#xfeff; &#xff08;2&#xff…

如何安装MySql

一.卸载MySql 1.1安装版 进入“控制面板”&#xff0c;将有关“mysql”的一切都删除&#xff0c;再到“C:\ProgramData”中&#xff0c;将“mysql”文件夹删除。 1.2压缩版 先在cmd中停止mysql服务 net stop mysql8 再删除解压“mysql”文件夹即可 二.安装MySql 2.2安装版…

RabbitMQ进阶_可靠性

文章目录 一、 发送者的可靠性1.1、 生产者重试机制1.2、 生产者确认机制1.2.1、确认机制理论1.2.2、确认机制实现1.2.2.1、定义ReturnCallback1.2.2.2、定义ConfirmCallback 二、 MQ的可靠性2.1、 数据持久化2.1.1、 交换机持久化2.1.2、 队列持久化2.1.3、 消息持久化 2.2、 …

端点物联网学习资源合集

端点物联网 学习资源合集 导航 1. 物联网实战--入门篇 文章链接 简介&#xff1a;物联网是一个包罗万象的行业和方向&#xff0c;知识碎片严重&#xff0c;本系列文章通过 边学边用 的思想&#xff0c;逐步建立学习者的信心和兴趣&#xff0c;从而进行更深入透彻的学习和探索…

IDEA如何用maven打包(界面和命令两种方式)

前言 我们在使用IDEA开发时&#xff0c;如果是springboot项目的话&#xff0c;一般是用maven来管理我们的依赖的。然后&#xff0c;当我们开发完成之后&#xff0c;就需要打包部署了。 那么&#xff0c;我们应该如何打包呢&#xff1f; 如何打包&#xff08;jar包&#xff09…

scrapy案例——链家租房数据的爬取

案例需求&#xff1a; 1.使用scrapy爬虫技术爬取链家租房网站&#xff08;成都租房信息_成都出租房源|房屋出租价格【成都贝壳租房】 &#xff09;的数据&#xff08;包括标题、价格和链接&#xff09; 2.利用XPath进行数据解析 3.保存为本地json文件 分析&#xff1a; 请…

(AtCoder Beginner Contest 375)B - Traveling Takahashi Problem

&#xff08;AtCoder Beginner Contest 375&#xff09;B - Traveling Takahashi Problem 题目大意 按顺序给定n个点 ( x i , y i ) (x_i,y_i) (xi​,yi​) 求按顺序走过这n个点并回到原点的总距离 任意两点之间的距离是欧几里得距离 思路 按照题意模拟即可&#xff0c;时间…