「CQOI2007」「BZOJ1260」涂色paint (区间dp
1260: [CQOI2007]涂色paint
Time Limit: 30 Sec Memory Limit: 64 MB
Submit: 2057 Solved: 1267
[Submit][Status][Discuss]
Description
每次你可以把一段连续的木版涂成一个给定的颜色,后涂的颜色覆盖先涂的颜色。例如第一次把木版涂成RRRRR,第二次涂成RGGGR,第三次涂成RGBGR,达到目标。
用尽量少的涂色次数达到目标。
Input
Output
Sample Input
Sample Output
AAAAA
【样例输入1】
RGBGR
【样例输出1】
1
【样例输出1】
3
HINT
40%的数据满足:1<=n<=10
100%的数据满足:1<=n<=50
题解
一道区间dp。
设F[L][R]为把[L,R]画完所需的最少次数。初始化F[i][j]=(j-i+1),表示暴力的一格格涂。
转移时,在[L,R]上枚举两个断点(L',R'),表示在[L,R]上直接覆盖一个区间[L',R']。
一开始让F[L][R]=F[L][L'-1]+F[L'][R']+F[R'+1][R],表示把大区间视为三个小区间,不在乎他们边界可能有缘。
- 如果L'上的颜色和L'-1相同,那么可以少画一次;
- 如果R'上的颜色和R'+1相同,那么可以少画一次;
- 如果L'-1上的颜色和R'+1上相同,那么又可以少画一次。
最后注意一下,因为假设在[L,R]上涂一层时,就算证明了这一层完全融入背景色,也不可能给原区间一个-1的buff,所以最多只能少画两次。
答案在F[1][n]。
我现在在怀疑是不是只用一个断点就可以解决问题
/**************************************************************
Problem: 1260
User: qwerta
Language: C++
Result: Accepted
Time:76 ms
Memory:1300 kb
****************************************************************/ #include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
char s[];
int f[][];
int chek(int i,int j)
{
if(s[i]==s[j])return ;//相同就可以少画一笔
else return ;
}
int main()
{
//freopen("a.in","r",stdin);
cin>>s;
int n=strlen(s);
for(int i=n;i;--i)
s[i]=s[i-];
for(int i=;i<=n;++i)
for(int j=i;j<=n;++j)
f[i][j]=(j-i+);//预处理
for(int len=;len<=n;++len)
for(int l=,r=len;r<=n;++l,++r)
{
for(int ll=l;ll<=r;++ll)
for(int rr=ll;rr<=r;++rr)
{
int k=f[l][ll-]+f[rr+][r]+f[ll][rr],g=;
if(ll->=l)g+=chek(ll-,ll);//左边界融入背景(///v///)
if(rr+<=r)g+=chek(rr,rr+);//右边界融入背景(///v///)
if(ll->=l&&rr+<=r)g+=chek(ll-,rr+);//左右边界是一样哒!(>w<)
k-=min(g,);//最多只能少画两笔QAQ
f[l][r]=min(f[l][r],k);
}
}
cout<<f[][n];
return ;
}
「CQOI2007」「BZOJ1260」涂色paint (区间dp的更多相关文章
- 【BZOJ-1260】涂色paint 区间DP
1260: [CQOI2007]涂色paint Time Limit: 30 Sec Memory Limit: 64 MBSubmit: 1147 Solved: 698[Submit][Sta ...
- [BZOJ1260][CQOI2007]涂色paint 区间dp
1260: [CQOI2007]涂色paint Time Limit: 30 Sec Memory Limit: 64 MB Submit: 1575 Solved: 955 [Submit][S ...
- BZOJ 1260: [CQOI2007]涂色paint( 区间dp )
区间dp.. dp( l , r ) 表示让 [ l , r ] 这个区间都变成目标颜色的最少涂色次数. 考虑转移 : l == r 则 dp( l , r ) = 1 ( 显然 ) s[ l ] = ...
- 【bzoj1260】[CQOI2007]涂色paint 区间dp
题目描述 给出一个序列,每次可以给一段染成同一种颜色,问最少要染多少次能够染成给定方案. 输入 输入仅一行,包含一个长度为n的字符串,即涂色目标.字符串中的每个字符都是一个大写字母,不同的字母代表不同 ...
- B1260 [CQOI2007]涂色paint 区间dp
这个题和我一开始想的区别不是很大,但是要我独自做出来还是有一些难度. 每一次涂色 只有这两种可能: 1) 把一段未被 覆盖过的区间 涂成 * 色 2) 把一段被一种颜色覆盖的区间涂成 * 色 (并且 ...
- CQOI2007 涂色 paint (区间dp)
听说这道题是当年省选题 于是兴致勃勃拿来做了做 至于如何想到思路... 事实上没想象中那么简单... 脑阔挺疼的... (一开始都没看出来是区间dp) 想到可以区间dp,然后就似乎没啥大问题 枚举区间 ...
- 【bzoj1260】涂色paint[CQOI2007](区间dp)
题目传送门:https://www.lydsy.com/JudgeOnline/problem.php?id=1260 这道题其实和codeforces607B有点像,然而做过原题的我居然没看出来.. ...
- 1260. [CQOI2007]涂色【区间DP】
Description 假设你有一条长度为5的木版,初始时没有涂过任何颜色.你希望把它的5个单位长度分别涂上红.绿.蓝.绿.红色,用一个长度为5的字符串表示这个目标:RGBGR. 每次你可以把一段连续 ...
- BZOJ1260 CQOI2007 涂色paint 【区间DP】
BZOJ1260 CQOI2007 涂色paint Description 假设你有一条长度为5的木版,初始时没有涂过任何颜色.你希望把它的5个单位长度分别涂上红.绿.蓝.绿.红色,用一个长度为5的字 ...
随机推荐
- C++精华笔记
牛客微信推送的C++笔记:2016-12-12 14:23:26 1.C++不仅支持面向对象,也可以像C一样支持面向过程. 2.OOP三大特性:封装 继承 多态 3.函数重载依据:函数类型and形 ...
- PS 基础知识 如何绘制几何图形
注意:规则的几何图形必须用路径工具,如果使用简单的椭圆工具再描边,则效果是像素堆砌起来的.图像一旦放大就是出现明显的失真. 使用钢笔工具,然后选择路径工具,然后选择需要绘制的图形. 如果需要找 ...
- 移动端底部input被弹出的键盘遮挡
https://developer.mozilla.org/zh-CN/docs/Web/API/Element/scrollIntoView 移动端input被键盘遮挡,事件是跳到可视区域! doc ...
- MRP routing设置释疑
Jeffer9@gmail.com 工艺是指在不同工作中心执行的作业序列 作业的详细信息 Number of cycles 在该工作中心操作几个循环 Number of ...
- Python生成8位随机字符串的一些方法
#第一种方法 import random import string seed = "1234567890abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOP ...
- orcad元件属性批量修改(通过excel表格)
本文适合于没有使用CIS的情况下,提高元件属性修改的效率和BOM生成. 第一步:编号 首先给元件编好号: 如果是沿用旧工程,用这个编号.如果是创建的新工程,使用第二项,强制从头开始编号.因为编号与PC ...
- Spring Cloud(十):服务网关zuul(转)
前面的文章我们介绍了,Eureka用于服务的注册于发现,Feign支持服务的调用以及均衡负载,Hystrix处理服务的熔断防止故障扩散,Spring Cloud Config服务集群配置中心,似乎一个 ...
- PHP后台批量删除数据
html <form action="" method="post"> <div><input type="submit ...
- Oracle学习(十三):闪回
1.知识点:能够对比以下的录屏进行阅读 SQL> --1. 错误地删除了记录 SQL> --2. 错误地删除了表 SQL> --3. 查询历史记录 SQL> --4. 怎样撤销 ...
- Day20 Java Socket使用
Java中Socket的使用 client端 package org.tizen.test; import java.io.IOException; import java.io.OutputStre ...