JAVA蓝桥杯备考---6.动态规划(一)

这篇具有很好参考价值的文章主要介绍了JAVA蓝桥杯备考---6.动态规划(一)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1.线性DP

动态规划简称 DP,通过把原问题分解为相对简单的子问题的方式求解复杂问题的方法。动态规划常常适用于有重叠子问题和最优子结构性质的问题。
简单来说,动态规划其实就是,给定一个问题,我们把它拆成一个个子问题,直到子问题可以直接解决然后呢,把子问题答案保存起来,以减少重复计算。再根据子问题答案反推,得出原问题解的一种方法。
动态规划最核心的思想,就在于拆分子问题,记住过往,减少重复计算。

动态规划的几个步骤
1.即划分子问题
2.状态表示。一般用数组dp[i]表示当前状态
3.状态转移,即当前状态是由前面那些状态转移过来的 例如 dp[i]=dpli-1],表示当前状态可以由上一个状态转移过来
4.确定边界,确定初始状态

线性DP是动态规划问题中的一类问题,指状态之间有线性关系的动态规划问题。
所谓线性DP,就是递推方程是有一个明显的线性关系的,一维线性和二维线性都有可能。
而我们在求的时候,有一个明显的求的顺序:即一行一行地来求。这样的有线性顺序的叫做线性DP

1.取钱 - 蓝桥云课 (lanqiao.cn)

/*
黄开的银行最近又发行了一种新面额的钞票面值为 4,所以现在黄
有5种面额的钞票,分别是 20.10.5.4.1但是不变的是他小
气,现在又有很多人来取钱,黄又不开心了,请你算出每个来取钱
的人黄应该给他至少多少张钞票
*/
import java.util.Arrays;
import java.util.Scanner;

public class 取钱 {

    static Scanner sc = new Scanner(System.in);

    public static void main(String[] args) {
        int[] arr = { 1, 4, 5, 10, 20 };
        int[] dp = new int[10001]; // 索引为金额, 值为方案数
        Arrays.fill(dp, 10000);
        dp[0] = 0; // 0金额的可选方案数量为0个
        for (int i = 1; i < dp.length; ++i) { // 枚举子问题金额数
            for (int j : arr) { // 每个子问题可选方案
                if (i >= j) { // 当金额大于等于面额时
                    dp[i] = Math.min(dp[i - j] + 1, dp[i]); // 选择当前面额后 +1,且寻找剩余金额时方案数累加,与当前j之后的面额继续对比方案数
                }
            }
        }
        while (sc.hasNext()) {
            System.out.println(dp[sc.nextInt()]);
        }
    }

}

2.破损的楼梯 - 蓝桥云课 (lanqiao.cn)

小蓝来到了一座高耸的楼梯前,楼梯共有N级台阶,从第0级台
阶出发。小蓝每次可以迈上1级或2级台阶。但是,楼梯上的第
a1级、第a2级第a3级,以此类推,共 M 级台阶的台阶面已经
坏了,不能踩上去。
现在,小蓝想要到达楼梯的顶端,也就是第N级台阶,但他不能
踩到坏了的台阶上。请问他有多少种不踩坏了的台阶到达顶端的方
案数?
由于方案数很大,请输出其对10^9+7取模的结果

2.二维DP 

 状态都只有一个维度,一般为dpli],称之为线性动态规划。
当维度有两个的时候,需要用二维的状态来解决问题,例如棋盘、矩阵、路径等类别的问题
更准确的说,二维动态规划指线性动态规划的拓展,在一个平面上做动态规划。

//题目大意:对于n*m的矩阵,每个点只能往下或者往右,计算从0,0点走到n-1,m-1点一共有多少种路径
解析: 我们定义dp数组 dp[i][j]为到达第i行,第j列的路径数。因为只能向下和右走推出状态转移方程为
dp[i][j]=dp[i-1][j]+dp[i][j-1]。dp数组初始状态为dp[0][0]=1,表示起点有一种方案。

1.传球游戏 - 蓝桥云课 (lanqiao.cn) 

1.摆花 - 蓝桥云课 (lanqiao.cn)

3.LIS

最长上升子序列,简称LIS。假设我们有一个序列bi,当b1<b2<..<bs的时候,我们称这个序列是上
升的。
对于给定的一个序列(a1,a2,.. aN),我们也可以从中得到一些上升的子序列(ai1, ai2,.., aik),这里1<=i1<i2<...<ik<= N,但必须按照从前到后的顺序。比如,对于序列(1,7,3,5,9,4,8),我们就会得到一些上升的子序列,如(1,7,9),(3,4,8),(1,3,5,8)等等,而这些子序列中最长的(如子序列(1,3,5,8)),它的长度为4,因此该序列的最长上升子序列长度为4。
这是一个经典dp问题。子序列指的是数组中不一定连续但先后顺序一致的n个数组。
在求解LIS问题中,我们一般定义dp[i]表示以索引i结尾的最长子序列长度。
可以退出状态转移方程为
if(dp[i]>dp[j])dp[i]=Math.max(dp[j]+1,dp[i]);(0<=j<i)
else dp[i]=Math.max(1,dp[i]);
时间复杂度为(n2)

1.蓝桥勇士 - 蓝桥云课 (lanqiao.cn)

4.LCS

LCS (最长公共子序列) 是一个经典的DP模型。
这节课我们讲解O(n^2)时间复杂度的LCS模型。
LCS问题是给定两个序列A和B,求它们的最长公共子序列。
在求解LCS时,一般我们会设dp[i][j]表示A [1~i]序列和B[1~j]序列中 (不规定结尾) 的最长
公共子序列的长度,状态转移方程为:
if a[i]=b[j];dp[i][j] = dp[i-1][j-1]+1
else dp[i][j] = max(dp[i-1][j],dp[i][j-1]);
解释一下:当a[i]=b[j]时,可以将他们作为插入到LCS的后面,使得长度变长1,当a[i]!=b[j]
时,说明此时LCS不会延长,那就要从dp[i-1][j]和dp[i][j-1]中取大的作为最长的长度。

1.最长公共子序列 - 蓝桥云课 (lanqiao.cn) 文章来源地址https://www.toymoban.com/news/detail-825708.html

到了这里,关于JAVA蓝桥杯备考---6.动态规划(一)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【蓝桥杯/动态规划】数的计算

    题目描述 输入一个自然数 n (n≤1000)n (n leq 1000) n   ( n ≤ 1 0 0 0 ) ,我们对此自然数按照如下方法进行处理: 不作任何处理; 在它的左边加上一个自然数,但该自然数不能超过原数的一半; 加上数后,继续按此规则进行处理,直到不能再加自然数为止。 问总共可以产生多少个数。

    2024年02月01日
    浏览(48)
  • 蓝桥杯-动态规划-子数组问题

    目录 一、乘积最大数组 二、乘积为正数的最长子数组长度 三、等差数列划分 四、最长湍流子数组 心得: 最重要的还是状态表示,我们需要根据题的意思,来分析出不同的题,不同的情况,来分析需要多少个状态 乘积最大数组 1.状态表示 dp[i]:到达i位置的最大乘积子数组。

    2024年02月05日
    浏览(35)
  • 蓝桥杯-回路计数(状态压缩、动态规划)

    蓝桥学院由 21 21 21 栋教学楼组成,教学楼编号 11 11 11 ​​ 到 21 21 21 ​​。对于两栋教学楼 a a a 和 b b b ​,当 a a a 和 b b b 互质时, a a a 和 b b b 之间有一条走廊直接相连,两个方向皆可通行,否则没有直接连接的走廊。 小蓝现在在第一栋教学楼,他想要访问每栋教学楼正

    2024年02月08日
    浏览(59)
  • 蓝桥:保险箱(Python,动态规划)

    小蓝有一个保险箱,保险箱上共有 n 位数字。小蓝可以任意调整保险箱上的每个数字,每一次操作可以将其中一位增加 1 或减少 1。当某位原本为 9 或 0 时可能会向前(左边)进位/退位,当最高位(左边第一位)上的数字变化时向前的进位或退位忽略。 例如: 00000 的第 5 位减

    2024年04月09日
    浏览(92)
  • 动态规划树形DP课后习题蓝桥舞会

      蓝桥舞会 题目描述 蓝桥公司一共有n名员工,编号分别为1~n。 他们之间的关系就像一棵以董事长为根的树,父节点就是子节点的直接上司。每个员工有一个快乐指数aj。 现蓝桥董事会决定举办一场蓝桥舞会来让员工们在工作之余享受美好时光,不过对于每个员工,他们都

    2024年02月21日
    浏览(47)
  • 【蓝桥杯C/C++】专题六:动态规划

    在这里插入图片描述 本专题将讲解 最难理解 的算法之一:动态规划。介绍动态规划的基本概念、算法原理以及应用场景。首先,我们将介绍动态规划的定义和特点,以及它与递归、贪心算法的区别。接着,我们将详细介绍动态规划的解题思路和算法流程,包括状态转移方程

    2024年02月01日
    浏览(48)
  • 蓝桥杯:最优包含--动态规划(C语言)

    1、S串用i进行遍历,T串用j进行遍历。 2、dp数组[i][j]的含义:S串中从S[0]到S[i],最少修改dp[i][j]个字符,可以包含T串中从T[0]到T[j]这部分字符串。 3、遍历时遇到的情况有两种: (1)情况一:S[i]==T[j]        dp[i][j]=min(dp[i-1][j],dp[i-1][j-1]);        dp[i-1][j]的含义:S[0]到S[i-1]中

    2024年02月16日
    浏览(39)
  • 蓝桥杯必备动态规划第二弹-路径问题进阶

    最小路径和 先看一眼题干什么意思-我们可以知道,左上角到右下角的最小路径和 1.状态表示(第一步其实是最重要,因为他可以确定状态转移方程) dp[i][j]:到ij位置,路径之和是最小 2.状态转移方程(为什么这么写,首先你要能到ij位置,其次你需要+ij位置的数字) dp[i][j

    2024年02月08日
    浏览(36)
  • 数字三角形-蓝桥杯真题动态规划PYTHON解法

    目录 题目描述  解题思路 DP初始化 DP最终条件 DP初始条件 题目限制条件 总代码 首先映入我们眼帘的就是一个三角形,加求路径和最大,类似于找最短路径的题,很明显是一个二维数组的动态规划问题,对于动态规划问题我们只需要找好最终条件,初始条件(也就是特殊条件

    2024年02月09日
    浏览(38)
  • 蓝桥杯动态规划第三弹-路径问题进阶2.0

    目录 一、删除并获得点数 二、粉刷房子 三、买卖股票最佳时机 四、手续费的买卖股票 删除并且获得点数 (我觉得这个还是较为复杂一点的) 我是开始一点没有思路,然后放弃这个题了——后来发现他有一个重要的思路,我从来没有发现过的一个思路。 nums[1,1,2,2,4,4,5,8,8

    2024年02月06日
    浏览(34)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包