备战蓝桥杯---动态规划的一些思想1

话不多说,直接看题:

目录

1.双线程DP

2.正难则反+多组DP

3.换个方向思考:


1.双线程DP

可能有人会说直接贪心:先选第1条的最优路径,再选第2条最优路径。

其实我们再选第1条时,我们怎么选会对第2条的路径产生影响,不满足无后效性。

我们选另一种思路:我们可以把问题看作A同时向B传2张纸条,我们令f[i][j][m][n]表示一张纸条在(i,j),另一个在(m,n)时的最优值,这样就满足了无后效性。

易得转移方程:

f[i][j][m][n]=a[i][j]+a[m][n]+max(f[i-1][j][m-1][n],f[i-1][j][m][n-1],f[i][j-1][m-1][n],f[i][j-1][m][n-1]).

同时,我们令f[i][j][i][j]为负无穷即可。

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
int m,n,a[60][60],dp[52][52][52][52];
int f(int i,int j,int x,int y){if(dp[i][j][x][y]!=-1){return dp[i][j][x][y];}if(i==x&&j==y) return dp[i][j][x][y]=-10000000;if(i-1>=1&&x-1>=1) dp[i][j][x][y]=max(dp[i][j][x][y],f(i-1,j,x-1,y));if(i-1>=1&&y-1>=1) dp[i][j][x][y]=max(dp[i][j][x][y],f(i-1,j,x,y-1));if(j-1>=1&&x-1>=1) dp[i][j][x][y]=max(dp[i][j][x][y],f(i,j-1,x-1,y));if(j-1>=1&&y-1>=1) dp[i][j][x][y]=max(dp[i][j][x][y],f(i,j-1,x,y-1));dp[i][j][x][y]+=a[i][j]+a[x][y];return dp[i][j][x][y];
}
int main(){cin>>m>>n;memset(dp,-1,sizeof(dp));dp[1][1][1][1]=0;for(int i=1;i<=m;i++){for(int j=1;j<=n;j++){cin>>a[i][j];}}cout<<f(m-1,n,m,n-1);
}

接题:

2.正难则反+多组DP

我们自然地想到用g[i][j]表示第i件物品不能带,背包大小为j的方案数。

直接求无从下手,我们考虑他其实就是背包大小为j的方案数-g[i][j-v[i]].

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
#define mod 10
int n,m,f[2350][2350],g[2350][2350],k[2350];
int main(){cin>>n>>m;for(int i=1;i<=n;i++) cin>>k[i];f[0][0]=1;for(int i=1;i<=n;i++){for(int j=0;j<=m;j++){if(j<k[i]) f[i][j]=f[i-1][j]%mod;else{f[i][j]=(f[i-1][j]%mod+f[i-1][j-k[i]]%mod)%mod;}}}for(int i=1;i<=n;i++){for(int j=1;j<=m;j++){if(j<k[i]) g[i][j]=f[n][j];else if(j==k[i])   g[i][j]=(f[n][j]-1+mod)%mod;else g[i][j]=(f[n][j]%mod-g[i][j-k[i]]%mod+mod)%mod;cout<<g[i][j]%mod;}cout<<endl;}
}

接题:

3.换个方向思考:

如果我们一行一行看,不像互不侵犯可以枚举,于是我们换个角度,我们斜着看,即:

我们发现,在斜着的一列,要敲某一个则必须把他斜上方的都敲了,因此,我们一定是敲的靠上的斜着的某一段。

同时他靠右的一斜列至少要敲到他的层数-1.这样子就合法了。

我们令f[i][j][k]表示前i列共敲了j块,第i列敲了k块。

易得转移方程:

f[i][j][k]=max(f[i-1][j-k][0--(k+1)]+sum[i][k]]).

下面是AC代码:

#include<bits/stdc++.h>
using namespace std;
int n,m,a[60][60],sum[60][60],dp[55][510][55];
int main(){cin>>n>>m;for(int i=1;i<=n;i++){for(int j=1;j<=n-i+1;j++){cin>>a[i][j];}}for(int i=1;i<=n;i++){for(int j=1;j<=n-i+1;j++){sum[i][j]=sum[i-1][j]+a[i][j];}}int ans=0;memset(dp,-0x3f,sizeof(dp));dp[n][0][0]=0;dp[n][1][1]=a[1][n];for(int i=n-1;i>=1;i--){for(int j=0;j<=m;j++){for(int k=0;k<=min(n-i+1,j);k++){for(int w=max(k-1,0);w<=n-i;w++){dp[i][j][k]=max(sum[k][i]+dp[i+1][j-k][w],dp[i][j][k]);ans=max(ans,dp[i][j][k]);}}}}cout<<ans;
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

在线开源免费问卷调查系统

在线开源免费问卷调查系统 平台简介 本项目旨在提供一个简单易用的问卷调查平台&#xff0c;帮助用户创建、分享问卷&#xff0c;并收集、分析调查数据。我们希望能够为各行各业的调查需求提供一种高效、便捷的解决方案。 项目特点 用户友好&#xff1a;清晰直观的用户界面…

华为数通方向HCIP-DataCom H12-821题库(多选题:21-40)

第21题 管理员在配置 VRRP 时,下面哪些不是必须配置的? A.抢占模式 B.抢占延时 C.虚拟IP 地址 D.虚拟路由器的优先级 【参考答案】ABD 【答案解析】 VRRP的作用之一是提供一个虚拟的IP地址,用作默认网关,用来实现冗余和故障转移。因此,配置虚拟IP地址是必须的。华为设备vr…

深入sizeof与strlen

一、sizeof与strlen的对比 sizeofstrlensizeof是单目操作符strlen是库函数&#xff0c;使用需要包含头文件string.hsizeof计算操作数所占用的内存&#xff0c;单位是字节strlen是求字符串长度&#xff0c;统计的是\0之前字符的个数不关注内存中存放什么数据 关注内存总是否有\0…

数据结构开篇

目录 一. 如何学好数据结构二. 基本概念和术语2.1 区分数据、数据元素、数据项、数据对象2.2 数据结构2.2.1 逻辑结构2.2.2 存储结构 2.3 数据类型和抽象数据类型2.4 抽象数据类型的实现 \quad 一. 如何学好数据结构 勤于思考;多做练习;多上机;善于寻求帮助;不怕困难&#xff…

基于springboot+vue的计算机课程管理平台(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

python爬虫之selenium知识点记录

selenium 一、前期准备 1、概述 selenium本身是一个自动化测试工具。它可以让python代码调用浏览器。并获取到浏览器中加载的各种资源。 我们可以利用selenium提供的各项功能。 帮助我们完成数据的抓取。 2、学习目标 掌握 selenium发送请求&#xff0c;加载网页的方法 掌…

划分开始结束位置设置标记

划分开始结束位置 初始音轨如下图所示 在想开始地方单击左键&#xff0c;长按直到你想要的结束位置松开。就可以划分开始和结束位置 设置标记 方式1 &#xff1a;直接点击该图标 方式二&#xff1a;使用快捷键M 设置标记点可以自定义名称方便检索标记点

React多个echarts图表在一个页面的使用

前景 很多情况下图标都是一个,我们大概率会像下面代码一样的做法 大概流程就是获取到数据后执行初始化,因为先初始化后异步请求再设置state里面的数据回导致无法正常显示echarts(除非再次调用setOption)下面就记录下自己解决过程源码 https://github.com/superBiuBiuMan/react-…

VMware安装Centos7详细过程

1.硬件软件准备 软件&#xff1a;VMware16 硬件&#xff1a;因为是在宿主机上运行虚拟化软件安装centos&#xff0c;所以对宿主机的配置有一定的要求。最起码I5CPU双核、硬盘500G、内存4G以上。 镜像&#xff1a;centos7,镜像下载地址centos安装包下载_开源镜像站-阿里云 2…

递归回溯剪枝-括号生成

LCR 085. 括号生成 - 力扣&#xff08;LeetCode&#xff09; 一. 根据题意&#xff0c;分析出符合要求的括号组合需要满足以下两个条件&#xff1a; 1. 左括号数或者右括号数都不能超过 n&#xff1b; 2. 从最左侧开始的每一个子集&#xff0c;不可以出现右括号数大于左括号数&…

使用python实现一个SCP小工具

源码地址&#xff1a; ssh_scp 工具截图&#xff1a; 一个简易的scp文件上传下载小工具&#xff0c;用来上传或下载一些小文件。 目前只适用于windows&#xff0c; 使用方法&#xff1a; 前提&#xff1a; 工具同级目录&#xff0c;创建一个ssh_commands.json文件。用来存储配…

pikachu验证XXE漏洞

先随便输入一个内容查看 服务器有回显 接下来用bp抓包看下参数 有个xml参数&#xff0c;而且Content-Type: application/x-www-form-urlencoded&#xff0c;我们传入url编码后的xml内容试一下 <?xml version"1.0" encoding"UTF-8"?> <!DOCTYP…