数据结构和算法-动态规划(1)-认识动态规划

认识动态规划

什么是动态规划

Dynamic Programming is a method used in mathematics and computer science to solve complex problems by breaking them down into simpler subproblems. By solving each subproblem only once and storing the results, it avoids redundant computations, leading to more efficient solutions for a wide range of problems.

动态规划(Dynamic Programming): 计算并存储小问题的解, 并将这些解组合成大问题的解。

动态规划如何工作

用一句名言开启

image-20241025112139383

Those Who Cannot Remember the Past Are Condemned(危险的) To Repeat It。

​ - 不记得过去的人注定要重蹈覆辙。

image-20241025090509359

看一个例子

计算: 1 + 1 + 1 + 1 + 1+ 1 + 1 + 1 = ?

image-20241025092515413

如果在等式左边添加1+, 即 **1 + **1 + 1 + 1 + 1 + 1+ 1 + 1 + 1=?

image-20241025092923122

如何快速的计算出答案?

image-20241025094601908

动态规划思路: 记住之前的求解,节省时间

再谈斐波拉切数列(Fibonacci )

兔子问题

image-20241025100237321

找出斐波拉切数列的数学归纳

分两种情况分析:

  • n=1,n=2 , 结果为 1
  • n>2, 结果为 n* (n-1) , n表示当前月

image-20241025101453728

构建代码(递归实现)

public int fib(int n) {
    if (n == 1 || n == 2) return 1;
    int res = fib(n - 1) + fib(n-2);
    return res;
}

分析递归实现

我们按照递归树进行分析,构建递归树模型。

image-20241025102343639

递归模型树的问题

image-20241025102854788 ·

优化方案

备忘录

自定向下的备忘录记忆,使用一个集合(数组)记录计算的结果防止重复计算。

package com.ffyc.dp;

public class Fib02 {

    public void fib(int n) {
        int[] remember = new int[n + 1]; //不使用n=0
        System.out.println(f(n, remember));
    }

    private int f(int n, int[] remember) {
        //如果remember中指定位置已经记录则直接返回,防止重复计算
        if (remember[n] != 0) {
            return remember[n];
        }
        //如果n==1,n==2则remember[1]=1, remember[2]=1
        if (n == 1 || n == 2) {
            remember[n] = 1;
        } else {
            remember[n] = f(n - 1, remember) + f(n - 2, remember);
        }
        return remember[n];
    }

    public static void main(String[] args) {
        new Fib02().fib(5);
    }
}

自低向上的动态规划
image-20241025110810355
public class Fib003 {
    public  int fib(int n){
        int[] remember = new int[n+1];

        remember[1] =1;
        remember[2] =1;

        for(int i = 3;i<=n;i++){
            remember[i] = remember[i-1]+ remember[i-2];
        }
        return remember[n];
    }

    public static void main(String[] args) {
        System.out.println(new Fib003().fib(5));
    }
}

实际上当前这个数组可以压缩为两个变量(a,b),当前的数由a,b迭代完成。–状态压缩

image-20241025111859562
public class Fib04 {

    public int fib(int n) {
        int a = 1;
        int b = 1;
        int c = 0;
        for (int i = 3; i <= n; i++) {
            c = a + b;
            a = b;
            b = c;
        }
        return c;
    }

    public static void main(String[] args) {
        System.out.println(new Fib04().fib(5));
    }
}

力扣斐波拉契问题

  1. [力扣LCR 126] LCR 126. 斐波那契数 - 力扣(LeetCode)
  2. [力扣 509] 509. 斐波那契数 - 力扣(LeetCode)
  3. [力扣1137] 1137. 第 N 个泰波那契数 - 力扣(LeetCode)]

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

centos-LAMP搭建与配置(论坛网站)

文章目录 LAMP简介搭建LAMP环境安装apache&#xff08;httpd&#xff09;安装mysql安装PHP安装php-mysql安装phpwind LAMP简介 LAMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写&#xff1a;Linux操作系统&#xff0c;网页服务器Apache&#xff0c;…

网络文件系统nfs实验1

服务端&#xff1a; 这个指令是搜索nfs相关的软件包 安装nfs相关的软件包&#xff1a; 列出已安装的nfs-utils软件包中的文件列表&#xff1a; 写配置文件&#xff1a;允许192.168.234.0/24这个网段的客户端能读写这个路径 重新导出所有当前已导出的文件系统&#xff1a; 启动…

DSPy:不需要手写prompt啦,You Only Code Once!

论文地址&#xff1a;https://arxiv.org/abs/2310.03714   项目地址&#xff1a;https://github.com/stanfordnlp/dspy 文章目录 1. 背景2. 签名3. 模块3.1 预测模块3.2 其他内置模块 4. 提词器5. 评估目标6. 代码分析6.1 _prepare_student_and_teacher6.2 _prepare_predicto…

【Docker】- WARNING: Found orphan containers XXX for this project.

报错展示 Creating network "net-10.9.0.0" with the default driver WARNING: Found orphan containers (server-4-10.9.0.8, server-3-10.9.0.7, server-1-10.9.0.5, server-2-10.9.0.6) for this project. If you removed or renamed this service in your compos…

Tomcat隐藏版本号和报错信息

为了避免漏洞扫描的时候造成版本泄露&#xff0c;可以在conf/server.xml配置文件中的<Host>配置项中添加如下配置: <Valve className"org.apache.catalina.valves.ErrorReportValve" showReport"false" showServerInfo"false" /> …

springboot案例

查询全部部门 项目结构 1. controller层 //日志注解,可以直接使用日志对象log.info Slf4j //用于指定将方法返回的对象转换为 JSON 或 XML 格式的响应体 RestController//DeptController.java //日志注解,可以直接使用日志对象log.info Slf4j //用于指定将方法返回的对象转换为…

Face Swap API 的整合与使用手册

Face Swap API 的整合与使用手册 Face Swap API 是一款功能强大的工具&#xff0c;能够通过提供一张源图像和一张目标图像&#xff0c;将目标图像中的人脸巧妙地替换为源图像中对应的位置。 在本手册中&#xff0c;我们将逐步指导您如何整合 Face Swap API&#xff0c;以便您…

Python金色流星雨

系列目录 序号直达链接爱心系列1Python制作一个无法拒绝的表白界面2Python满屏飘字表白代码3Python无限弹窗满屏表白代码4Python李峋同款可写字版跳动的爱心5Python流星雨代码6Python漂浮爱心代码7Python爱心光波代码8Python普通的玫瑰花代码9Python炫酷的玫瑰花代码10Python多…

Linux:编辑器Vim和Makefile

✨✨所属专栏&#xff1a;Linux✨✨ ✨✨作者主页&#xff1a;嶔某✨✨ vim的三种常用模式 分别是命令模式&#xff08;command mode&#xff09;、插入模式&#xff08;Insert mode&#xff09;和底行模式&#xff08;last line mode&#xff09; 各模式的功能区分如下&…

使用C#学习Office文件的处理(pptx docx xlsx)

Office文件 是指PPT 、word、Excel 这些常用工具生成的文件 &#xff0c;例如 pptx docx xlsx。 这些文件的读取和生成有很多很多库 例如 NOPI 、DevExpress、C1、Aspose、Teleric 等等&#xff0c;各有各的优缺点。俺今天不讲这个&#xff0c;俺只是讲讲如何了解Office文件的…

xtu Euler‘s Totient Function+欧拉函数

Eulers Totient Function 样例输入 3 1 6 1 100 1 1000000样例输出 12 3044 303963552392 解题思路&#xff1a; 不管是素数还是合数&#xff0c;初始值都是它本身。 j为素数&#xff0c;f[j]j-1&#xff0c;相当于f[j]j/i*(i-1),ij 埃筛&#xff0c;ji,i为j的…

基于微信小程序实现信阳毛尖茶叶商城系统设计与实现

作者简介&#xff1a;Java领域优质创作者、CSDN博客专家 、CSDN内容合伙人、掘金特邀作者、阿里云博客专家、51CTO特邀作者、多年架构师设计经验、多年校企合作经验&#xff0c;被多个学校常年聘为校外企业导师&#xff0c;指导学生毕业设计并参与学生毕业答辩指导&#xff0c;…

利用这五项网络安全措施安全地扩展您的数据中心

由于大量行业使用这些设施&#xff0c;数据中心网络安全至关重要。医疗保健、金融、教育和其他行业都依赖此存储解决方案来保护记录和敏感信息。 公司可能会根据需求调整存储需求&#xff0c;因此了解网络安全协议至关重要。以下是如何在保护数据中心免受外部攻击的同时扩展数…

C++stack和queue的模拟实现

1.stack的模拟实现 在这一部分嘞&#xff0c;我们不再用传统的模拟实现来实现今天要实现的内容&#xff0c;我们使用一种设计模式来实现今天的内容 设计模式 目前接触到的设计模式一共有两种&#xff1a;一种是适配器模式&#xff0c;一种是迭代器模式 迭代器设计模式 迭代…

linux内核的原子操作与用户态的原子操作差别

Linux内核的原子操作与用户态的C语言原子操作主要在以下几个方面存在区别&#xff1a; 实现层级&#xff1a; 内核原子操作&#xff1a; 直接依赖于硬件提供的原子指令&#xff08;如CAS、原子加等&#xff09;&#xff0c;通过内核提供的函数&#xff08;如atomic_add()、at…

多目标优化求解的内涵主要方法

多目标优化问题 定义如下多目标优化问题&#xff1a; min ⁡ f ( x ) [ f 1 ( x ) , f 2 ( x ) , ⋯ , f n ( x ) ] ( 1 ) \min\quad f(x)[f_1(x),f_2(x),\cdots,f_n(x)]\quad(1) minf(x)[f1​(x),f2​(x),⋯,fn​(x)](1) 其中&#xff0c; f i ( x ) , ∀ i 1 , ⋯ , n f_…

TS中forEach与map,filter的简单事例及简单的说明

1、先上一张效果图&#xff1a; 2、再上一个代码&#xff1a; <template><div><h1>Array Test</h1><ul><li v-for"item in items" :key"item.id">{{ item.name }}</li></ul><div style"display:…

攻防世界的新手web题解

攻防世界引导模式 1、disabled_button 好&#xff0c;给了一个按钮&#xff0c;第一道题目就不会做 看的wp<input disabled class"btn btn-default" style"height:50px;width:200px;" type"submit" value"flag" name"auth&q…

嵌入式软开——八股文——学习引导和资料网址

1、找工作期间整理的相关八股资料&#xff0c;可以帮助初学者按此流程快速学习入门&#xff0c;帮助有基础的同学快速复习、查缺补漏&#xff0c;帮助找工作面试的同学&#xff0c;快速复习知识点。 2、前13个文件夹为单独模块的相关学习内容&#xff0c;里面涵盖相关模块的主…

【C++复习】第二弹-内存管理

目录 前言 1.结合地址空间来理解不同对象的存储区域 2.malloc和free以及new和delete的区别 3.什么是内存泄漏&#xff1f; 前言 对于一个程序来说&#xff0c;我们必须知道他的各个位置的变量存放在哪里的&#xff0c;所以我们必须要清楚C的内存分布。其实内存管理是衡量一个…