BZOJ2121 字符串游戏 【dp】

题目链接

BZOJ2121

题解

dp怎么那么神呐QAQ

我们要求出最小字符串长度

我们设一个\(dp[i]\)表示前\(i\)个字符最后所形成的最短字符串长度

对于第\(i\)个字符,要么保留,就是\(dp[i] = dp[i - 1]\),要么和前面若干个字符一起被删掉

我们设\(c[i][j]\)表示区间\([i,j]\)能否被删掉

如果我们能求出\(c[i][j]\)就好了

我们再设一个\(f[i][j][k][t]\)表示区间\([i,j]\)能否匹配第\(k\)个串的前\(t\)个字符

如果存在一个\(k\),使得\(f[i][j][k][len[k]]\)为真,那么\(c[i][j]\)就为真

所以我们只需考虑如何求出\(f[i][j][k][t]\)

就是简单的区间\(dp\)啦

枚举断点\(d\),然后\(f[i][j][k][l] |= f[i][d][k][t] \&\& c[d + 1][j]\)

注意转移的顺序,因为\(f\)和\(c\)是同时计算的,倒序枚举即可

然后就做完啦

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<algorithm>
#define LL long long int
#define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt)
#define REP(i,n) for (int i = 1; i <= (n); i++)
#define BUG(s,n) for (int i = 1; i <= (n); i++) cout<<s[i]<<‘ ‘; puts("");
using namespace std;
const int maxn = 155,maxm = 100005,INF = 1000000000;
int f[maxn][maxn][32][23],dp[maxn],c[maxn][maxn],len[32],n,m;
char S[maxn],s[32][23];
int main(){
    scanf("%s",S + 1); m = strlen(S + 1);
    scanf("%d",&n);
    REP(i,n) scanf("%s",s[i] + 1),len[i] = strlen(s[i] + 1);
    for (int i = m; i; i--){
        for (int j = i; j <= m; j++){
            for (int k = 1; k <= n; k++){
                f[i][i - 1][k][0] = 1;
                for (int l = 1; l <= len[k]; l++){
                    f[i][j][k][l] = (f[i][j - 1][k][l - 1] && S[j] == s[k][l]);
                    for (int d = i; d < j; d++)
                        f[i][j][k][l] |= (f[i][d][k][l] && c[d + 1][j]);
                }
            }
            for (int k = 1; k <= n; k++) c[i][j] |= f[i][j][k][len[k]];
        }
    }
    for (int i = 1; i <= m; i++){
        dp[i] = dp[i - 1] + 1;
        for (int j = 1; j <= i; j++) if (c[j][i]) dp[i] = min(dp[i],dp[j - 1]);
    }
    printf("%d\n",dp[m]);
    return 0;
}

原文地址:https://www.cnblogs.com/Mychael/p/8993229.html

时间: 2024-10-08 03:00:51

BZOJ2121 字符串游戏 【dp】的相关文章

BZOJ2121 字符串游戏

Description BX正在进行一个字符串游戏,他手上有一个字符串L,以及其 他一些字符串的集合S,然后他可以进行以下操作:对于一个在集合S中的字符串p,如果p在L中出现,BX就可以选择是否将其删除,如果删除,则将删除后L 分裂成的左右两部分合并.举个例子,L='abcdefg' , S={'de'},如果BX选择将'de'从L中删去,则删后的L='abcfg'.现在BX可以进行任意多次操作(删的次数,顺序都随意),他想知道最 后L串的最短长度是多少. Input 输入的第一行包含一个字符串

[LuoguP1005]矩阵取数游戏 (DP+高精度)

题面 传送门:https://www.luogu.org/problemnew/show/P1005 Solution 我们可以先考虑贪心 我们每一次都选左右两边尽可能小的数,方便大的放在后面 听起来挺OK的 实则并不OK 反例: 3 1 1 1 1 1 2 2 2 2 2 2 2 2 2 2 如果贪心的话,我们会优先把右边那一串2先选了,再去选3和1 但是正确答案显然是先把3和1选了,再去选那一串2 既然贪心不成,我们可以考虑一下DP 然后我们考虑这样一个状态: f[i][j][k] 表示第i

游戏 DP

游戏 DP [题意描述] 小喵喵喜欢玩 RPG 游戏.在这款游戏中,玩家有两个属性,攻击和防御,现在小喵喵的攻击和防御都是 1,接下来小喵喵会依次遇到 n 个事件.事件有两种. 1.小喵喵经过修炼,角色升级了,此时可以选择攻击+1 或者防御+1. 2.小喵喵遇到了一个敌人,可以选择战斗或者逃跑.如果战斗, 胜利后得到 a[i]金钱.如果逃跑,则无事发生,但是以后也不能再 回来打这个怪物了. 对于一场战斗来说,如果小喵喵的攻击力大于等于 atk[i],防御 力大于等于 def[i],那么他可以无伤

【bzoj2121】字符串游戏 区间dp

题目描述 给你一个字符串L和一个字符串集合S,如果S的某个子串在S集合中,那么可以将其删去,剩余的部分拼到一起成为新的L串.问:最后剩下的串长度的最小值. 输入 输入的第一行包含一个字符串,表示L. 第二行包含一个数字n,表示集合S中元素个数. 以下n行,每行一个字符串,表示S中的一个元素. 输入字符串都只包含小写字母. 输出 输出一个整数,表示L的最短长度. 样例输入 aaabccd3acabcaaa 样例输出 2 题解 我们考虑:每次删除连续的一段,对应到原串上即:删除 $[l,r]$ 中所

bzoj5147&amp;&amp;bzoj2121&amp;&amp;loj6701 字符串游戏

做不出来杂题,到处找题做 看到$loj$上新出了一道题,觉得很神仙不错, 还记得Censoring吗(一个AC自动机的题) 这个题求最优解,数据范围$150$ 题解 数据范围非常小,首先贪心肯定不行,考虑AC自动机上$dp$? 好吧其实是区间$dp$ 一个直接的想法是维护$f[l][r]=0/1$表示是否可以清空$l$,$r$这一段子段 然而转移起来很难转移,考虑再定义一个数组$g[l][r][i][w]=0/1$表示是否可以清成第$i$个模式串的前$w$位 考虑$g$转移, 1.直接匹配$g[

字符串游戏(strgame)——博弈

题目 [题目描述] pure 和 dirty 决定玩 $T$ 局游戏.对于每一局游戏,有 $n$ 个字符串,并且每一局游戏由 $K$ 轮组成.具体规则如下:在每一轮游戏中,最开始有一个空串,两者轮流向串的末尾添加一个字符,并且需要保证该串为 $n$ 个字符串中任意一个串的前缀,不能操作的人输掉这一轮,并且在下一轮游戏中由该轮输掉的人先手.另外为了遵循女士优先的原则,在每一局游戏的第一轮均由 pure 先手. 玩家的目标是获得整局游戏的胜利,一局游戏的胜利条件是:对手输掉最后一轮游戏.我们可以假定

UVa11584Partitioning by Palindromes(字符串区间dp)

题意:给定一个字符串s, 问说最少可以划分成几个回文串. 思路:dp[i]表示从1到第i个字符最少可以划分为几个回文,状态转移方程 dp[i] = min(dp[i], dp[j-1]+1),  如果满足 s[j] 到 s[i] 为回文字符串. 用 judge 函数判断从j到i是否可以形成回文串. Sample Input 3 racecar fastcar aaadbccb Sample Output 1 7 3 <span style="font-size:18px;">

Luogu P1057 传球游戏(dp 递推)

P1057 传球游戏 题目描述 上体育课的时候,小蛮的老师经常带着同学们一起做游戏.这次,老师带着同学们一起做传球游戏. 游戏规则是这样的:n个同学站成一个圆圈,其中的一个同学手里拿着一个球,当老师吹哨子时开始传球,每个同学可以把球传给自己左右的两个同学中的一个(左右任意),当老师再次吹哨子时,传球停止,此时,拿着球没有传出去的那个同学就是败者,要给大家表演一个节目. 聪明的小蛮提出一个有趣的问题:有多少种不同的传球方法可以使得从小蛮手里开始传的球,传了m次以后,又回到小蛮手里.两种传球方法被视

vijos 1464 积木游戏 DP

描述 积木游戏 SERCOI 最近设计了一种积木游戏.每个游戏者有N块编号依次为1 ,2,…,N的长方体积木.对于每块积木,它的三条不同的边分别称为"a边"."b边"和"c边" 游戏规则如下:1.从N块积木中选出若干块,并将它们分成M(l<=M<=N) 堆,称为第1堆,第2 堆…,第M堆.每堆至少有1块积木,并且第K堆中任意一块积木的编号要大于第K+1堆中任意一块积木的编号(2<=K<=M). 2.对于每一堆积木,游戏者要