[HAOI2016]字符合并

时间限制:C/C++ 1秒,其他语言2秒
空间限制:C/C++ 262144K,其他语言524288K
64bit IO Format: %lld

题目描述

有一个长度为 n 的 01 串,你可以每次将相邻的 k 个字符合并,得到一个新的字符并获得一定分数。得到的新字符和分数由这 k
个字符确定。你需要求出你能获得的最大分数。 输入描述: 第一行两个整数n,k。 接下来一行长度为n的01串,表示初始串。
接下来2k行,每行一个字符ci和一个整数wi,ci
表示长度为k的01串连成二进制后按从小到大顺序得到的第i种合并方案得到的新字符,wi表示对应的第i种方案对应获得的分数。 1 ≤ n ≤
300,0 ≤ ci ≤ 1,wi ≥ 1, k ≤ 8

输出描述:

输出一个整数表示答案

示例1
输入
复制

3 2
101
1 10
1 10
0 20
1 30

输出
复制

40

题解:

一开始愣是没看懂题意
长度为k的01串连成二进制后按从小到大顺序,这句话我们用样例来讲就是
00,01,10,11这四个从小到大排列
分数分别是输入的10,10,20,30

参考题解
区间dp+状压dp
dp[l][r][s]表示区间[l,r]合并为s的最小代价
经过推到可以得到:当串的长度为 lenlen 时,最后该串的长度为 (len-1) mod (k-1)+1
区间dp问题就是枚举中间的端点,把区间[l,r]拆分成[l,mid]和[mid+1,r]

状态定义:

f[l][r][S<<1]=max(f[l][r][S<<1],f[l][mid][S]+f[mid+1][r][0]);
f[l][r][S<<1|1]=max(f[l][r][S<<1|1],f[l][mid][S]+f[mid+1][r][1]);

区间[mid+1,r]相当于已经合并完了,因为合并完的值就是0或1,直接加到前面区间[l,mid]上,f[l][mid][S]则是看[l,mid]这段区间合并成多少

当区间长度正好为k时,就直接合并,更新数据(用两个临时变量先储存)
g[c[S]]=max(g[c[S]],f[l][r][S]+w[S]);
区间[l,r]合并为c[S]的最大值,然后
f[l][r][0]=g[0];f[l][r][1]=g[1];
g[]就是临时变量

代码:

#include <bits/stdc++.h>
using namespace std;
#define LL long long
#define INF 0x3f3f3f3f
LL f[310][310][(1<<8)+20];
char s[310];
int b[(1<<8)+20];
LL c[(1<<8)+20];
int main()
{int n,m,k,i,j;scanf("%d%d",&n,&k);scanf("%s",s+1);for(i=0; i<(1<<k); ++i)scanf("%d%lld",b+i,c+i);memset(f,-INF,sizeof(f));LL inf=f[0][0][0];for(i=1; i<=n; ++i) f[i][i][s[i]-'0']=0;for(int len=2; len<=n; ++len){for(i=1; i+len-1<=n; ++i){j=i+len-1;int l=(j-i)%(k-1);if(!l) l=k-1;for(int las=j; las>=i; las-=k-1){for(int S=0; S<(1<<l); ++S){if(f[i][las-1][S]==inf) continue;if(f[las][j][0]!=inf)f[i][j][S<<1]=max(f[i][j][S<<1],f[i][las-1][S]+f[las][j][0]);if(f[las][j][1]!=inf);f[i][j][S<<1|1]=max(f[i][j][S<<1|1],f[i][las-1][S]+f[las][j][1]);}}if(l==k-1){LL g[2]= {inf,inf};for(int S=0; S<(1<<k); ++S){if(f[i][j][S]!=inf){g[b[S]]=max(g[b[S]],f[i][j][S]+c[S]);}}f[i][j][0]=g[0];f[i][j][1]=g[1];}}}LL ans=0;int l=n%(k-1)?n%(k-1):k-1;for(i=0; i<(1<<l); ++i)ans=max(ans,f[1][n][i]);cout<<ans<<endl;return 0;
}

[HAOI2016]字符合并(ing)相关推荐

  1. [BZOJ4565][Haoi2016]字符合并(区间状压dp)

    Address https://www.lydsy.com/JudgeOnline/problem.php?id=4565 Solution 区间合并让人想到区间 dp ,而 k≤8k≤8k\le8 ...

  2. bzoj4565 [HAOI2016]字符合并 结论+状压+区间dp

    如果k==2的话就是记搜, 但这个题用记搜的思路的话是需要枚举k个断点的, 所以对于枚举断点,就很可能有优化,比如到一个断点,一个决策的最优值 于是考虑区间dp模型,相当于是插入一个数,然后看影响. ...

  3. 【BZOJ 4565】 [Haoi2016]字符合并 区间dp+状压

    考试的时候由于总是搞这道题导致爆零~~~~~(神™倒序难度.....) 考试的时候想着想着想用状压,但是觉得不行又想用区间dp,然而正解是状压着搞区间,这充分说明了一件事,状压不是只是一种dp而是一种 ...

  4. jexcel可以合并单元格么_含金量超高的3个文本、字符合并实用技巧解读!

    当各位亲看到此篇文章时,说明已是2019年1月1日呢,感谢各位亲对小编的支持和厚爱,在这里祝福各位亲元旦快乐,"19"快乐,事业有成--同时,小编会继续努力为各位亲开发更多的实用技 ...

  5. Python 将字符串转换成单个字符;将单个字符合并成字符串

    # 将字符串转换成单个字符: s = "kkjjasd" # 1 for i in s:print(i)# 2 k = list(s) print(k)# 3 g = set(s) ...

  6. mysql按指定长度拆分_MySQL按指定字符合并及拆分

    按照指定字符进行合并或拆分是经常碰到的场景,MySQL在合并的写法上比较简单,但是按指定字符拆分相对比较麻烦一点(也就是要多写一些字符).本文将举例演示如何进行按照指定字符合并及拆分. 1. 合并 M ...

  7. 把两个字符合并成单个字符(0,a 合成0x0a)

    最近弄一个项目过程中,因为串口数据传输时,协议要求把0x0a拆成2个字符0和a,换成十六进制就是0x30和0x41两个字符发送,但是数据包填充后要用CRC校验,CRC校验确又是用的原字符去校验,即把0 ...

  8. 每天一道LeetCode-----将字符串的连续相同的字符合并成一个字符后加个数

    Count and Say 原题链接 Count and Say 求出第n个表达式,第n个表达式由第n-1个表达式的读音构成.如 第3个表达式为21,读作1个2,1个1,所以第4个表达式就是1211. ...

  9. excel字符合并技巧:几种连接字符串的方法助你高效办公

    [前言] 在使用EXCEL的实际应用中,我们经常会为了统计方便,把数据元素分的相对详细一些,那么统计的维度也就会多一些.同样的,有的时候我们也需要把拆分的很详细的内容,再合并成一个内容放在一个单元格中 ...

最新文章

  1. html在页面上div绝对定位,html – 中心浮动div在绝对定位div内
  2. 阿里转衰!百度没落!字节跳动崛起!未来的互联网是腾讯和字节跳动的世界!这样的言论你相信吗?...
  3. 大数据挖掘会让我们避免下一场瘟疫么?
  4. 【Leetcode】背包问题模板
  5. Linux中基础指令
  6. SOL注入——基于联合查询的数字型GET注入(二)
  7. 快速入门MyBatis-Plus,看这一篇就够了。
  8. SpringSecurity安全框架
  9. java以下属于合法标识符的是_2012年计算机二级Java合法标识符章节练习题及答案...
  10. 如何在Windows 10上安装Python
  11. 每日算法系列【LeetCode 233】数字 1 的个数
  12. 中小学创客教室建设,教育创客空间整体解决方案
  13. 视频 Docker 学习(高级篇)
  14. 自适应控制与鲁棒控制的区别
  15. 同一网络下的两台计算机怎样共享,如何实现在windows下同一网络两台电脑文件共享互传?...
  16. Cassandra的Allow Filtering
  17. php molten,当molten遇到机器学习
  18. PDF文件如何在线翻译成中文
  19. 在vue项目中快速使用element UI
  20. vulnhub Earth:解题思路

热门文章

  1. 你们要的印度布线,这是一种极端的牛X
  2. SparkSQL DataFrame进阶篇
  3. android activity解耦,Android与设计模式:用单一职责原则为Activity解耦
  4. 学计算机要买什么样的电脑,大学开学要买电脑吗?又要买什么样的电脑?看准这些再买也不迟!...
  5. windows server 2003中 如何限制用户修改计算机名,Windows命令行下修改文件访问控制权限 -电脑资料...
  6. java io操作_Java 的IO操作(文件的读,写操作)
  7. linux脚本启三个tomcat,linux 重写Tomcat启停脚本
  8. leetcode115. 不同的子序列
  9. [SpringSecurity]基本原理_过滤器链
  10. [JavaWeb-MySQL]多表查询(内连接,外连接,子查询)