dp状态设计
迎接仪式
题目描述
LHX 教主要来 X 市指导 OI 学习工作了。为了迎接教主,在一条道路旁,一群“Orz 教主 er”穿着文化衫站在道路两旁迎接教主,每件文化衫上都印着大字。一旁的 Orzer 依次摆出“欢迎欢迎欢迎欢迎……”的大字,但是领队突然发现,另一旁穿着“教”和“主”字文化衫的 Orzer 却不太和谐。
为了简单描述这个不和谐的队列,我们用 j
替代“教”,z
替代“主”。而一个 j
与 z
组成的序列则可以描述当前的队列。为了让教主看得尽量舒服,你必须调整队列,使得 jz
子串尽量多。每次调整你可以交换任意位置上的两个人,也就是序列中任意位置上的两个字母。而因为教主马上就来了,时间仅够最多做 \(K\) 次调整(当然可以调整不满 \(K\) 次),所以这个问题交给了你。
输入格式
第一行,两个正整数 \(N, K\),分别表示序列长度与最多交换次数。
第二行,一个长度为 \(N\) 的字符串,字符串仅由字母 j
与字母 z
组成,描述了这个序列。
输出格式
一个非负整数,为调整最多 \(K\) 次后最后最多能出现多少个 jz
子串。
样例 #1
样例输入 #1
5 2
zzzjj
样例输出 #1
2
提示
【样例说明】
第 \(1\) 次交换位置 \(1\) 上的 z
和位置 \(4\) 上的 j
,变为 jzzzj
;
第 \(2\) 次交换位置 \(4\) 上的 z
和位置 \(5\) 上的 j
,变为 jzzjz
。
最后的串有 \(2\) 个 jz
子串。
【数据规模与约定】
对于 \(10 \%\) 的数据,有 \(N \le 10\);
对于 \(30 \%\) 的数据,有 \(K \le 10\);
对于 \(40 \%\) 的数据,有 \(N \le 50\);
对于 \(100 \%\) 的数据,有 \(1 \le N \le 500\),\(1 \le K \le 100\)。
题解:
这题的状态是非常难想出来的除非看题解
主要思路是把交换变为改变记录下\('j','z'\)改变的次数
这样做的好处是可以不用考虑当前\('j','z'\)是和哪个位置的\('j','z'\)交换的(可前可后)
就可以更加方便的进行dp(线性的往后推)
因为要考虑当前\('j'/'z'\)的贡献(即能不能和前面的字母组成\(jz\))所以还有记下当前状态下末尾字符是\('j'/'z'\)
因为一次交换\('j','z'\)都会改变一次所以到最后\('j','z'\)的改变次数相同才是合法状态
状态\(:f[i][j][k][0/1]\)表示前\(i\)个字符中交换\(j\)次\('j'\)和\(k\)次\('z'\)且第\('i'\)个字符改为\('j'/'z'\)所能得到的最多\(jz\)的数量。
状态出来了转移就很好写了
std:
#include<bits/stdc++.h>
using namespace std;
#define re register
#define max_(x,y) x>y?x:y
const int N = 501;
int n,m,f[2][N][N][2];
char s[N];
int main()
{
scanf("%d%d%s",&n,&m,s+1);
memset(f,128,sizeof f);
f[0][0][0][1] = 0;
for(re int i = 1;i <= n;i++)
for(re int j = 0;j <= m;j++)
for(re int k = 0;k <= m;k++)
if(s[i] == 'j')
{
f[i&1][j][k][0] = max_(f[(i&1)^1][j][k][0],f[(i&1)^1][j][k][1]);
if(j)f[i&1][j][k][1] = max_(f[(i&1)^1][j-1][k][0]+1,f[(i&1)^1][j-1][k][1]);
}
else
{
if(k)f[i&1][j][k][0] = max_(f[(i&1)^1][j][k-1][0],f[(i&1)^1][j][k-1][1]);
f[i&1][j][k][1] = max_(f[(i&1)^1][j][k][1],f[(i&1)^1][j][k][0]+1);
}
int ans = 0;
for(re int i = 1;i <= m;i++)ans = max(ans,max_(f[n&1][i][i][1],f[n&1][i][i][0]));
printf("%d",ans);
return 0;
}
dp状态设计的更多相关文章
- 1113: [视频]树形动态规划(TreeDP)8:树(tree)(树形dp状态设计总结)
根据最近做的几道树形dp题总结一下规律.(从这篇往前到洛谷 P1352 ) 这几道题都是在一颗树上,然后要让整棵树的节点或边 满足一种状态.然后点可以影响到相邻点的这种状态 然后求最小次数 那么要从两 ...
- 教主泡嫦娥[有趣的dp状态设计]
P1342 教主泡嫦娥 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 2012年12月21日下午3点14分35秒,全世界各国的总统以及领导人都已经汇聚在中国 ...
- Dp状态设计与方程总结
1.不完全状态记录<1>青蛙过河问题<2>利用区间dp 2.背包类问题<1> 0-1背包,经典问题<2>无限背包,经典问题<3>判定性背包问 ...
- Codeforces 889E - Mod Mod Mod(dp+状态设计)
Codeforces 题目传送门 & 洛谷题目传送门 题目名称 hopping 我们记 \(x_i=X\bmod a_1\bmod a_2\bmod\dots\bmod a_i\),也就是 \ ...
- 关于一类容斥原理设计 dp 状态的探讨
写在前面 为什么要写?因为自己学不明白希望日后能掌握. 大体思路大概是 设计一个容斥的方案,并使其贡献可以便于计算. 得出 dp 状态,然后优化以得出答案. 下列所有类似 \([l,r]\) 这样的都 ...
- dp状态压缩
dp状态压缩 动态规划本来就很抽象,状态的设定和状态的转移都不好把握,而状态压缩的动态规划解决的就是那种状态很多,不容易用一般的方法表示的动态规划问题,这个就更加的难于把握了.难点在于以下几个方面:状 ...
- HDU 4336 Card Collector (期望DP+状态压缩 或者 状态压缩+容斥)
题意:有N(1<=N<=20)张卡片,每包中含有这些卡片的概率,每包至多一张卡片,可能没有卡片.求需要买多少包才能拿到所以的N张卡片,求次数的期望. 析:期望DP,是很容易看出来的,然后由 ...
- HDU 1074 Doing Homework (dp+状态压缩)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1074 题目大意:学生要完成各科作业, 给出各科老师给出交作业的期限和学生完成该科所需时间, 如果逾期一 ...
- hdu_4352_XHXJ's LIS(数位DP+状态压缩)
题目连接:hdu_4352_XHXJ's LIS 题意:这题花大篇篇幅来介绍电子科大的一个传奇学姐,最后几句话才是题意,这题意思就是给你一个LL范围内的区间,问你在这个区间内最长递增子序列长度恰为K的 ...
- hdu 4352 数位dp + 状态压缩
XHXJ's LIS Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total ...
随机推荐
- kratos v2版本命令行工具使用
使用 下载 go install github.com/go-kratos/kratos/cmd/kratos/v2@latest 查看是否安装成功 kratos -v kratos version ...
- 运用Filebeat module分析nginx日志
在同一台主机上事先安装好filebeat,elasticsearch和kibana filebeat配置 安装完Filebeat后,可以看到在Filebeat的安装目录下有一个叫做filebeat.y ...
- 查看pod创建时使用yaml文件内容
除了 kubectl describe pod 以外,另一种获取 Pod 额外信息(除了 kubectl get pod)的方法 是给 kubectl get pod 增加 -o yaml 输出格式参 ...
- Nexus OSS 3 搭建并配置使用 Docker & Git LFS 仓库
转载自:https://cloud.tencent.com/developer/article/1010590 1.Nexus OSS 3 介绍 我们知道 Nexus 是一个强大的 Maven 仓库管 ...
- 各编程语言 + aardio 相互调用示例
代码简单.复制可用.aardio 快速调用 C,C++,C#,Java,R,V,Python,JavaScript,Node.js,Rust,PHP,Ruby,PowerShell,Fortran,D ...
- centos 安装mysql 8.0
在home下新建一个mysql文件夹 cd /home mkdir mysql cd mysql 1.首先上传文件,把文件传到 /home/mysql下 链接:https://pan.baidu.co ...
- CentOS 7.9 安装 MySQL 5.7.35
CentOS 7.9 安装 MySQL 5.7.35 1 下载地址:https://downloads.mysql.com/archives/community/ 2 mysql5.7.35 安装包上 ...
- acwing1782 Dynamic Rankings (整体二分)
和整体二分的模板相比,多了修改操作. 1 #include<bits/stdc++.h> 2 using namespace std; 3 const int N=1e5+10,INF=1 ...
- VScode开发STM32/GD32单片机-MakeFile工程JlinkRTT配置
本次使用开发板为STM32F401CCU6,使用CubeMX配置一个Makefile工程 配置时候为内部时钟 工程选择makefile工程类型 只生成需要的文件 用VSCode打开后显示很多波浪线 选 ...
- flutter系列之:把box布局用出花来
目录 简介 LimitedBox SizedBox FittedBox 总结 简介 flutter中的layout有很多,基本上看layout的名字就知道这个layout到底是做什么用的.比如说这些l ...