题解[SCOI2009]粉刷匠 难度:省选/NOI-
Description
每条木板被分为 M 个格子。
每个格子要被刷成红色或蓝色。
windy每次粉刷,只能选择一条木板上一段连续的格子,然后涂上一种颜色。
每个格子最多只能被粉刷一次。
如果windy只能粉刷 T 次,他最多能正确粉刷多少格子?
一个格子如果未被粉刷或者被粉刷错颜色,就算错误粉刷。
Input
接下来有N行,每行一个长度为M的字符串,'0'表示红色,'1'表示蓝色。
Output
Sample Input
3 6 3
111111
000000
001100
Sample Output
16
Data Constraint
Hint
这道题很显然是一道动态规划题,但是我们发现,如果我们想用一个动态规划去做这道题,那么状态和转移都会十分的麻烦,这时候我们就要想是否需要两个动态规划来完成一个复杂的过程,我们看到这道题如果只问每一行的最优结果,那么转移就会很简单,所以我们可不可以将这个问题转化成先求每一行粉刷k次的最优解再求前i行操作k次的最优解。
既然思路确定,那么我们就可以设状态了:1-设置g数组表示在第i行,粉刷j次,刷到k的最优解,2-设置f表示前i行,刷j次的最优解。
转移方程也很好写:1- g[i][j][k]=max(g[i][j][k],max(用前缀和计算在p到k之间最多可以有多少正确的)+g[i][j-1][p]); p是从j-1开始枚举的,具体为什么代码上有注释,k是从j开始的,因为j进行了j次粉刷后最少粉刷到j点。
关于f的是 f[i][j]=max(f[i-1][j-k]+g[i][k][m]).
下面上代码:
#include<iostream>
#include<cstdio>
using namespace std;
int f[][],sum[][]; //f表示前i行刷j次最大对值。
int g[][][]; //第i行,刷到第j个用k次粉刷得到的最大对值。
int n,m,t;
char s[];
int main(){
ios::sync_with_stdio();
cin>>n>>m>>t;
for(int i=;i<=n;i++){
cin>>s;
sum[i][]=;
for(int j=;j<=m;j++){
if(s[j-]=='') sum[i][j]=sum[i][j-]+;
else sum[i][j]=sum[i][j-];
}
}
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
for(int k=j;k<=m;k++){
for(int p=j-;p<k;p++){ //因为q是第j-1次粉刷,每一次粉刷至少一格,所以q最少为j-1.
g[i][j][k]=max(g[i][j][k],max(sum[i][k]-sum[i][p],k-p-sum[i][k]+sum[i][p])+g[i][j-][p]);
}
}
}
}
for(int i=;i<=n;i++){
for(int j=;j<=t;j++){
for(int k=;k<=min(j,m);k++){
f[i][j]=max(f[i][j],f[i-][j-k]+g[i][k][m]);
}
}
}
int ans=;
for(int i=;i<=t;i++){
ans=max(ans,f[n][i]);
}
cout<<ans;
}
题解[SCOI2009]粉刷匠 难度:省选/NOI-的更多相关文章
- BZOJ 1296: [SCOI2009]粉刷匠 分组DP
1296: [SCOI2009]粉刷匠 Description windy有 N 条木板需要被粉刷. 每条木板被分为 M 个格子. 每个格子要被刷成红色或蓝色. windy每次粉刷,只能选择一条木板上 ...
- 【BZOJ1296】[SCOI2009]粉刷匠(动态规划)
[BZOJ1296][SCOI2009]粉刷匠(动态规划) 题面 BZOJ 洛谷 题解 一眼题吧. 对于每个串做一次\(dp\),求出这个串刷若干次次能够达到的最大值,然后背包合并所有的结果即可. # ...
- 【BZOJ1296】[SCOI2009]粉刷匠 (DP+背包)
[SCOI2009]粉刷匠 题目描述 \(windy\)有 \(N\) 条木板需要被粉刷. 每条木板被分为 \(M\) 个格子. 每个格子要被刷成红色或蓝色. \(windy\)每次粉刷,只能选择一条 ...
- bzoj1296: [SCOI2009]粉刷匠(DP)
1296: [SCOI2009]粉刷匠 题目:传送门 题解: DP新姿势:dp套dp 我们先单独处理每个串,然后再放到全局更新: f[i][k]表示当前串枚举到第i个位置,用了k次机会 F[i][j] ...
- BZOJ 1296: [SCOI2009]粉刷匠( dp )
dp[ i ][ j ] = max( dp[ i - 1 ][ k ] + w[ i ][ j - k ] ) ( 0 <= k <= j ) 表示前 i 行用了 j 次粉刷的机会能正 ...
- 1296: [SCOI2009]粉刷匠[多重dp]
1296: [SCOI2009]粉刷匠 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1919 Solved: 1099[Submit][Statu ...
- 背包 DP【洛谷P4158】 [SCOI2009]粉刷匠
P4158 [SCOI2009]粉刷匠 windy有 N 条木板需要被粉刷. 每条木板被分为 M 个格子. 每个格子要被刷成红色或蓝色. windy每次粉刷,只能选择一条木板上一段连续的格子,然后涂上 ...
- BZOJ_1296_[SCOI2009]粉刷匠_DP
BZOJ_1296_[SCOI2009]粉刷匠_DP Description windy有 N 条木板需要被粉刷. 每条木板被分为 M 个格子. 每个格子要被刷成红色或蓝色. windy每次粉刷,只能 ...
- [Bzoj1296][Scoi2009] 粉刷匠 [DP + 分组背包]
1296: [SCOI2009]粉刷匠 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 2184 Solved: 1259[Submit][Statu ...
随机推荐
- [2019杭电多校第六场][hdu6635]Nonsense Time
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6635 题意是说一开始所有数都冻结,第i秒会解冻第ki个数,求每秒状态下的最长上上升子序列长度. 这种题 ...
- wxpython中单选框的两种创建方式源码展示
#coding=utf-8 import wx class MyFrame(wx.Frame): def __init__(self): wx.Frame.__init__(self,None,-1, ...
- JVM 垃圾回收(GC)机制
目录 一.背景 二. 哪些内存需要回收? 1.引用计数算法 2 .可达性分析算法 三. 四种引用状态 1.强引用 2.软引用 3.弱引用 4.虚引用 对象死亡(被回收)前的最后一次挣扎 方法区如何判断 ...
- 解析安装mysql
大多数人在结束咱们前面学习的基础知识的时候,其实一脸懵逼,不过我们已经开始步入了另一个新的高度,针对基础知识还是必须巩固针对性的进行补充,可以分模块总结:比如基础知识的数据结构---->函数-- ...
- ideamaven版的MBG逆向工程
一.简介 简称MBG,是一个专门为MyBatis框架使用者定制的代码生成器,可以快速的根据表生成对应的映射文件,接口,以及bean类. 支持基本的增删改查,以及QBC风格的条件查询. 但是表连接.存储 ...
- Taro -- 原生微信小程序转taro
微信小程序转Taro (转发https://nervjs.github.io/taro/docs/taroize.html) Taro 可以将你的原生微信小程序应用转换为 Taro 代码,进而你可以 ...
- linux里面以指定用户运行命令
一.chroot方式 [root@localhost ~]# chroot --userspec "nginx:nginx" "/" sh -c "w ...
- 三、ARM 寄存器及异常处理
3.1 ARM 内部寄存器 ARM920T 总共有 37 个寄存器,其中 31 通用 32 位寄存器和 6 个状态寄存器,但不能在同一时刻对所有的寄存器可见.处理器状态和运行模式决定了哪些寄存器对程序 ...
- hdu 6045: Is Derek lying? (2017 多校第二场 1001)【找规律】
题目链接 可以暴力找一下规律 比如,假设N=7,两人有5题相同,2题不同,枚举X=0->15时,Y的"Not lying"的取值范围从而找出规律 #include<bi ...
- 【Java】commons-lang3中DateUtils类方法介绍
添加commons-lang3的Maven依赖 <dependency> <groupId>org.apache.commons</groupId> <art ...