迎接仪式

题目描述

LHX 教主要来 X 市指导 OI 学习工作了。为了迎接教主,在一条道路旁,一群“Orz 教主 er”穿着文化衫站在道路两旁迎接教主,每件文化衫上都印着大字。一旁的 Orzer 依次摆出“欢迎欢迎欢迎欢迎……”的大字,但是领队突然发现,另一旁穿着“教”和“主”字文化衫的 Orzer 却不太和谐。

为了简单描述这个不和谐的队列,我们用 j 替代“教”,z 替代“主”。而一个 jz 组成的序列则可以描述当前的队列。为了让教主看得尽量舒服,你必须调整队列,使得 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状态设计的更多相关文章

  1. 1113: [视频]树形动态规划(TreeDP)8:树(tree)(树形dp状态设计总结)

    根据最近做的几道树形dp题总结一下规律.(从这篇往前到洛谷 P1352 ) 这几道题都是在一颗树上,然后要让整棵树的节点或边 满足一种状态.然后点可以影响到相邻点的这种状态 然后求最小次数 那么要从两 ...

  2. 教主泡嫦娥[有趣的dp状态设计]

    P1342 教主泡嫦娥 时间: 1000ms / 空间: 131072KiB / Java类名: Main 背景 2012年12月21日下午3点14分35秒,全世界各国的总统以及领导人都已经汇聚在中国 ...

  3. Dp状态设计与方程总结

    1.不完全状态记录<1>青蛙过河问题<2>利用区间dp 2.背包类问题<1> 0-1背包,经典问题<2>无限背包,经典问题<3>判定性背包问 ...

  4. Codeforces 889E - Mod Mod Mod(dp+状态设计)

    Codeforces 题目传送门 & 洛谷题目传送门 题目名称 hopping 我们记 \(x_i=X\bmod a_1\bmod a_2\bmod\dots\bmod a_i\),也就是 \ ...

  5. 关于一类容斥原理设计 dp 状态的探讨

    写在前面 为什么要写?因为自己学不明白希望日后能掌握. 大体思路大概是 设计一个容斥的方案,并使其贡献可以便于计算. 得出 dp 状态,然后优化以得出答案. 下列所有类似 \([l,r]\) 这样的都 ...

  6. dp状态压缩

    dp状态压缩 动态规划本来就很抽象,状态的设定和状态的转移都不好把握,而状态压缩的动态规划解决的就是那种状态很多,不容易用一般的方法表示的动态规划问题,这个就更加的难于把握了.难点在于以下几个方面:状 ...

  7. HDU 4336 Card Collector (期望DP+状态压缩 或者 状态压缩+容斥)

    题意:有N(1<=N<=20)张卡片,每包中含有这些卡片的概率,每包至多一张卡片,可能没有卡片.求需要买多少包才能拿到所以的N张卡片,求次数的期望. 析:期望DP,是很容易看出来的,然后由 ...

  8. HDU 1074 Doing Homework (dp+状态压缩)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1074 题目大意:学生要完成各科作业, 给出各科老师给出交作业的期限和学生完成该科所需时间, 如果逾期一 ...

  9. hdu_4352_XHXJ's LIS(数位DP+状态压缩)

    题目连接:hdu_4352_XHXJ's LIS 题意:这题花大篇篇幅来介绍电子科大的一个传奇学姐,最后几句话才是题意,这题意思就是给你一个LL范围内的区间,问你在这个区间内最长递增子序列长度恰为K的 ...

  10. hdu 4352 数位dp + 状态压缩

    XHXJ's LIS Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

随机推荐

  1. Python数据科学手册-机器学习之特征工程

    特征工程常见示例: 分类数据.文本.图像. 还有提高模型复杂度的 衍生特征 和 处理 缺失数据的填充 方法.这个过程被叫做向量化.把任意格式的数据 转换成具有良好特性的向量形式. 分类特征 比如房屋数 ...

  2. (数据科学学习手札143)为geopandas添加gdb文件写出功能

    本文示例代码已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 大家好我是费老师,很多读者朋友跟随着我先前写作的 ...

  3. 在PyQt5中使用Pandas时的几个坑

    最近在看Python GUI编程,在用到PyQt5+Pandas时遇到一些问题.这里把问题和解决方法整理一下.备查. (好像不能上传附件,内容只好写在下面了.) 在PyQt5中使用Pandas时的几个 ...

  4. Echarts中tooltip解决显示指定数据

    今天开发中遇到一个问题,echarts图表触摸x轴触发tooltip会将x轴上所有的数据展示出来,但是有些场合只需要展示某些数据就可以,并不需要全部展示,如下图: 这里警戒线因为需要开关,所以使用填充 ...

  5. 10.Ceph 基础篇 - RGW 高可用

    文章转载自:https://mp.weixin.qq.com/s?__biz=MzI1MDgwNzQ1MQ==&mid=2247485316&idx=1&sn=d3a6be41 ...

  6. img通过修改css等比例缩小图片

    css中加上:object-fit:cover 例子: img{ width: 200px; height: 400px; object-fit: cover; }

  7. 齐博x1客服系统显示客户在哪个页面

    如下图所示,要想实现下面的效果,即显示客户给你发消息时,当时处于哪个商品页面.这样方便跟客户针对此商品进行交流. 你的模板如果使用了碎片的话,就可以添加下面的代码index_style/default ...

  8. 28.解析器Parser

    什么是解析器 因为前后端分离,可能有json.xml.html等各种不同格式的内容 后端也必须要有一个解析器来解析前端发送过来的数据 不然后端无法处理前端数据 后端有一个渲染器Render,和解析器是 ...

  9. 【MySQL】04_约束

    约束 概述 为了保证数据的完整性,SQL规范以约束的方式对表数据进行额外的条件限制.从以下四个方面考虑: 实体完整性(Entity Integrity) :例如,同一个表中,不能存在两条完全相同无法区 ...

  10. Seata 环境搭建

    在使用微服务中,单体事务注解@Transactional 就不适用了,需要采用分布式事务解决方案,本文介绍分布式事务Seata的安装.Seata一款开源的分布式事务解决方案,致力于在微服务架构下提供高 ...