蓝桥杯之动态规划冲刺

news2025/1/11 12:51:12

文章目录

  • 动态规划
    • 01背包
      • 小练一下
      • 01背包
      • 网格图上的DP
      • 完全背包
    • 最长公共字符串
    • 最长递增子序列

动态规划

在这里插入图片描述
在这里插入图片描述

  • 动态规划:确定好状态方程,我们常常是确定前 当状态来到 i 时,前 i 个物体的状态是怎么样的,我们并不是从一个点去考虑,也就是说虽然我们分割问题,但是问题是相互联系的,那么这就是区别于递归的本质区别

在这里插入图片描述

01背包

在这里插入图片描述
由于不能拆开,那就是DP 问题,如果能拆开,那就是贪心问题

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

小练一下

01背包

在这里插入图片描述

import os
import sys

# 请在此输入您的代码

N,V = map(int,input().split())

w = []
v = []
w.append(0)
v.append(0)

for i in range(N):
  a,b = map(int,input().split())
  w.append(a)
  v.append(b)

dp = [[0]*(V+1) for _ in range(N+1)]

for i in range(1,N+1):# 取出第i 个物品
  for j in range(V+1):

    if j-w[i]<0:
      dp[i][j]=dp[i-1][j]
    else:
      dp[i][j]=max(dp[i-1][j],dp[i-1][j-w[i]]+v[i])

print(dp[N][V])


在这里插入图片描述
在这里插入图片描述

  • 可以对空间进行优化:只用添加两个变量来存储new,old 就是利用滚动数组,两个数组即可解决

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

import os
import sys

V = int(input())#####箱子容量
n = int(input())####物品数量
l = [0]####各自体积
for i in range(n):####输入体积
  l.append(int(input()))
dp = [[0 for j in range(V+1)]for i in range(n+1)]

for i in range(1,n+1):###
  for j in range(1,V+1):####
    if j < l[i]:####
      dp[i][j] = dp[i-1][j]
    else:
      dp[i][j]=max(dp[i-1][j],dp[i-1][j-l[i]]+l[i])###
print(V-dp[n][V])

同样的思路:还是用二维数组存储,dp[i][j]表示 前i 个物体在空间j 的情况下,所能放的空间的大小

网格图上的DP

在这里插入图片描述

  • 对于网格的问题,咋一看好像可以用搜索来解决,但是搜索的话可能就会超时,所以我们可以用动态规划来做,那么如何进行定义?
    dp[i][j] 就是走到(i,j) 的时候的路径数,那么就有 动态规划的式子 :
    dp[i][j] = dp[i-1][j] + dp[i][j-1] 得来
    对于不能到达的地方,就直接 设置dp 值为0即可
    巧妙地地方:让出发点以及🐎所在地点以及终点都偏移,这样就可以方便解决出界地问题
import os
import sys

# 请在此输入您的代码

bx, by, mx, my = map(int, input().split())

bx += 2
by += 2
mx += 2
my += 2

dp = [[0] * (30) for i in range(30)]

s = [[False] * 30 for i in range(30)]

dp[2][1] = 1
s[mx][my] = True

s[mx - 1][my - 2] = True
s[mx - 1][my + 2] = True
s[mx - 2][my - 1] = True
s[mx - 2][my + 1] = True
s[mx + 1][my - 2] = True
s[mx + 1][my + 2] = True
s[mx + 2][my - 1] = True
s[mx + 2][my + 1] = True

for i in range(2, bx + 1):

    for j in range(2, by + 1):

        if s[i][j]:
            dp[i][j] = 0
        else:
            dp[i][j] = dp[i - 1][j] + dp[i][j - 1]

print(dp[bx][by])


完全背包

在这里插入图片描述

  • 完全背包问题就是在01 背包的基础上,每一件物品是没有个数的限制的,不过可以参照01 背包的思路,因为当第i 种物品的第一件物品就是01 背包问题,后面就是要考虑第 i 件物品
    状态方程
    1.dp[i][j] 表示前 i 种物品,在空间为 j 下能够装下的最大的价值
    2.那么当 pw[i] 第 i 件物品占用的体积大于 j 的时候,那么就只能
    dp[i][j] = dp[i-1][j]
    3.当pw[i] 第 i 件物品占用的体积小于等于 j 的时候,那么就是考虑第i 种物品选不选的问题了,也就是
    dp[i][j] = max(dp[i-1][j] ,dp[i][j-pw[i]]+pv[i])
    其中,dp[i-1][j] 是考虑不选第i 种物品,dp[i][j-pw[i]]+pv[i](01背包的本质区别)是在选了第i 种物品的基础上,再选几件的问题
import os
import sys

# 请在此输入您的代码


N,V = map(int ,input().split())
pw=[0]
pv=[0]
dp = [[0]*(V+1) for i in range(N+1)]

for i in range(N):
  a,b = map(int,input().split())
  pw.append(a)
  pv.append(b)

for i in range(1,N+1):
  for j in range(1,V+1):

    if j<pw[i]:
      dp[i][j] = dp[i-1][j]
    else:
      dp[i][j] = max(dp[i-1][j],dp[i][j-pw[i]]+pv[i])

print(dp[N][V])


最长公共字符串

在这里插入图片描述

  • 对于这个问题,我们就要考虑从二维方面出发:
    dp[i][j] 表示前i 个 x 的字符 和前 j 个 y 的字符的最长的公共子序列的长度
    1.当x[i]==y[j] 的时候,那么就直接是dp[i][j] = dp[i-1][j-1] +1
    2.不相等的时候,就是dp[i][j] = max(dp[i-1][j],dp[i][j-1])

对于统计数目的话,还在研究:

import os
import sys

# 请在此输入您的代码

x = input()
y = input()

# dp[i][j] 表示 x=xi 与 y=yj 时x与y 的最大的公共子序列的长度
lenx = len(x)
leny = len(y)

dp = [[0]*(len(y)) for i in range(len(x))]

for i in range(lenx):
    if x[i]==y[0]:
        dp[i][0]=1
for i in range(leny):
    if x[0]==y[i]:
        dp[0][i]=1

for i in range(1,lenx):
  for j in range(1,leny):

      if x[i]==y[j]:
        dp[i][j]=dp[i-1][j-1]+1
      else:
        dp[i][j]=max(dp[i-1][j],dp[i][j-1])

length =dp[lenx-1][leny-1]
sum=0
for i in range(lenx):
  for j in range(leny):
      if dp[i][j]==length:
        sum = sum +1
        sum = sum%100000000
print(length)
print(sum)

最长递增子序列

在这里插入图片描述
在这里插入图片描述

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

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

相关文章

【1】THIS IS NOT PROLIFIC PL2303. PLEASE CPMTACT YOUR SUPPLIER

0x01 问题描述 连接COM口连接不上&#xff0c;出现THIS IS NOT PROLIFIC PL2303. PLEASE CPMTACT YOUR SUPPLIER.如下图 0x02 问题解决 1、分析后&#xff0c;因为是windows 11 系统&#xff0c;就装一下驱动。右键单击--》属性 2、更新驱动程序--》浏览我的电脑以查找驱动程序…

企业应如何建立有效的内控制度?

内部控制制度&#xff08;以下简称“内控制度”&#xff09;作为企业生产经营活动自我调节、自我约束的内在机制&#xff0c;在企业管理系统中具有举足轻重的作用。内部控制制度的建立、健全及实施情况的好坏&#xff0c;是企业生产经营成败的关键。因此&#xff0c;企业应该建…

粒子群算法 - 目标函数最优解计算

粒子群算法概念 粒子群算法 (particle swarm optimization&#xff0c;PSO) 由 Kennedy 和 Eberhart 在 1995 年提出&#xff0c;该算法模拟鸟群觅食的方法进行寻找最优解。基本思想&#xff1a;人们发现&#xff0c;鸟群觅食的方向由两个因素决定。第一个是自己当初飞过离食物…

软件工程-第三版王立福-第1章 绪论

本书结合IEEE最新发布的软件工程体系SWEBOK&#xff0c;和IEEE/ACM软件工程学科小组公布的软件工程教育知识体系SEEK&#xff0c;北大本科生指定教材。注重基础知识的系统性&#xff0c;选材的先进性及知识的应用。2009年出版 软件开发本质的认识&#xff0c;两大技术问题&…

【Linux】Linux基本开发工具(yum) (vi/vim)的使用

本文章内容&#xff1a; 学习yum工具&#xff0c;进行软件安装掌握vim编辑器使用 Linux 软件包管理器 yum 什么是软件包 在Linux下安装软件, 一个通常的办法是下载到程序的源代码, 并进行编译, 得到可执行程序.但是这样太麻烦了, 于是有些人把一些常用的软件提前编译好, 做成…

一文带你详解天池工业数据集

人工智能是国家战略性新兴产业&#xff0c;制造业是国民经济的主体&#xff0c;随着人口红利的消失&#xff0c;加强设备自动化改造&#xff0c;提高生产自动化程度&#xff0c;减小劳动强度&#xff0c;改善作业环境&#xff0c;已经成为制造业的普遍共识。天池大赛开放出一批…

MySQL中的基本SQL语句

MySQL中的基本SQL语句 查看操作 1. 查看有哪些数据库 show databases; 2.切换数据库 use 数据库名;比如切换至 mysql数据库 use mysql;3.查看数据库中的表 show tables;4.查看表中数据 select 要查询的东西 from 表名 [ where 条件 ];select * from 表名…

大众EA111发动机

大众EA111发动机_什么是大众EA111发动机_太平洋汽车百科 大众EA111发动机_什么是大众EA111发动机_太平洋汽车百科 大众的EA111系列发动机是大众公司小排量发动机的主力&#xff0c;有1.2L、1.4L、1.6L三种排量。大众的EA111系列发动机融合了缸内直喷、涡轮增压等先进技术&…

数据库报Statement cancelled due to timeout错误处理方法

如上图&#xff0c;如果数据库报错&#xff0c;可考虑是事务导致锁表问题。 解决方法&#xff1a; 1.查看下在锁的事务 SELECT * FROM INFORMATION_SCHEMA.INNODB_TRX; 2&#xff0c;kill第一步查出的线程ID

EasyExcel模板填充list时按第一行格式合并单元格(含分页线设置)

前言&#xff1a; 在使用easyExcel填充list时&#xff0c;第一行存在合并单元格的情况下&#xff0c;后面使用forceNewRow()填充的行却没有合并样式。 模板&#xff1a; 填充后&#xff1a; 自定义拦截器&#xff1a; 根据官方文档的提示&#xff0c;我们需要自定义拦截器来…

backtrader回测股票:突破20日均线买入,跌破20日均线卖出

数据源&#xff1a;akshare 回测工具&#xff1a;backtrader 策略&#xff1a;突破20日均线买入&#xff0c;跌破20日均线卖出 代码&#xff1a; from datetime import datetime import backtrader as bt #1.9.78.123 import matplotlib.pyplot as plt #3.8.3 import aks…

[Qt学习笔记]QT下获取Halcon图形窗口鼠标事件并执行相应操作

目录 1、背景2、参考信息3、目标4、步骤4.1 Halcon库的配置4.2 读取图像&#xff0c;并实现图像自适应窗体控件大小4.3 主要的图形绘制和贴图操作见如下代码&#xff0c;其中重点为全局函数的创建来实现选择Select、拖拽Drag和尺寸Resize事件响应。 5、总结 1、背景 在视觉项目…

春暖花开,一起来看看2024年品牌春分海报吧!

春分&#xff08;Vernal equinox&#xff09;已至&#xff0c;春花烂漫、燕子归来、百草回芽。 今天我们要分享的是2024年品牌发布的春分节气海报合集&#xff0c;快来随我们一起感受这昂扬、蓬勃的春意吧! &#xff08;1&#xff09;泸州老窖 &#xff08;2&#xff09;BD…

C语言——自定义类型——结构体(从零到一的跨越)

目录 前言 1.什么是结构体 2.结构体类型的声明 2.1结构体的声明 2.2结构体的创建和初始化 2.3结构成员访问操作符 2.3.1结构体成员直接访问 2.3.2结构体成员的间接访问 2.4结构体变量的重命名 2.5结构体的特殊声明 2.6结构的自引用 3.结构体内存对齐 3.1对齐规则 3…

docker harbor.v2.9.2搭建镜像无法下载问题解决

在通过部署docker harbor时&#xff0c;采用的是离线包的方式&#xff0c;当解压压缩包后&#xff0c;执行prepare脚本步骤中有一步是要获取prepare:v2.9.2版本镜像 结果执行脚本时报如下错误&#xff1a; Unable to find image goharbor/prepare:v2.9.2 locally 这时候我们就…

网络: DHCP 协议简介

文章目录 1. 前言2. DHCP 协议简介2.1 DHCP 客户端广播 DHCPDISCOVER 消息2.2 DHCP 服务器回复 DHCPOFFER 消息2.3 DHCP 客户端广播 DHCPREQUEST 消息2.4 DHCP 服务器回复 DHCPACK 消息2.5 剩余的工作 3. 参考资料 1. 前言 限于作者能力水平&#xff0c;本文可能存在谬误&…

【Linux】shell命令运行原理---认识Linux基本指令

主页&#xff1a;醋溜马桶圈-CSDN博客 专栏&#xff1a;Linux_醋溜马桶圈的博客-CSDN博客 gitee&#xff1a;mnxcc (mnxcc) - Gitee.com 目录 1.shell命令以及运行原理 1.1 shell命令 1.2 Linux内核权限 1.3 图示Linux shell和bash的区别 2.认识Linux基本指令 2.1 指令的…

Vue.js前端开发零基础教学(一)

目录 第一章 初识Vue.js 前言 开发的好处 一.前端技术的发展 什么是单页Web应用&#xff1f; 二. Vue的简介 三. Vue的特性 四. Vue的版本 五.常见的包管理 六.安装node环境 第一章 初识Vue.js 学习目标&#xff1a; 了解前端技术的发展 了解什么是Vue掌握使用方…

Zero-Shot Learning with Joint Generative Adversarial Networks 中文版

目录 摘要介绍1.研究背景和意义2.先前的模型提出了什么方法&#xff1f;解决了什么问题&#xff1f;有什么不足&#xff1f;3.最近的研究提出了什么方法&#xff1f;解决了什么问题&#xff1f;4.最新的研究提出了什么方法&#xff1f;解决了什么问题&#xff1f;有什么不足&am…

关于自己Nginx的使用(ant design pro 部署)

一 原因 工作需要部署 ant design pro 框架开发的前端程序&#xff0c;并且需要有用到代理。就选择了nginx部署。 二 使用nginx部署 ant design pro 框架程序 1. 前端项目打包 &#xff08;1&#xff09;打包命令&#xff1a;npm run build 或者 yarn bulid &#…