IOI2016Day2. paint
题目链接:http://uoj.ac/problem/238
题目大意:
有一个长度为n的黑白序列,告诉你所以k个极长连续黑段长度和顺序。有一些位置的颜色已知,需要判断剩下未知的位置哪
些颜色
一定是白或一定是黑。保证至少存在一组解。
分析:
先猜测,根据数据范围,虽然n很大,但是k却很小,可以考虑复杂度为O(n*k)的算法。(* ̄︶ ̄)
我们再来具体看看,可以设状态:
f0[i][j] 表示前i个位置能匹配j段并且i位置为白是否合法。
f1[i][j] 表示前i个位置能匹配j段并且i位置为黑是否合法,可以O(n*k)求出。
但这样却又漏洞,我们只是保证了从前往后i,j合法,但是我们还不能保证在这种情况满足后面i+1到n-1是否合法,大概就是我们不能保证
剩下的位置够不够。
为了解决这个问题我们再定义两个状态,g0[i][j],g1[i][j]从后往前来记录。
这样状态转移就是:
if(a[i]!=X) f[i][j][0]=f[i-1][j][0]|f[i-1][j][1] (可以与前面一个组成一组,也可以接在一个黑色后面,有一种满足都合法)
if(i-b[j]>=0&&sum[i]-sum[i-b[j]]==0)f[i][j][1]=f[i-b[j]][j-1][0];(在i-b[j]+1-i直接没有X&&i-b[j]位置为白)
g的转移一样,只是从后往前处理。
答案:
如果f[i][j][0]==1&&g[i][j+1][0](表示从前往后第i个位置满足j段并且当前为白色时合法&&从i到n-1满足j+1到m段的块,并且当前
为白色合法)
两个都合法说明i就可以为白色,用y记录是否为白色。
如果f[i][j][1]==1&&g[i+1][j+1][0](上面类似,当前为黑,那么下一位就要为白)
两个都合法说明i就可以为黑色,用个x记录一个数能为黑色的数量,如果最后x>0说明可以为黑色。
统计:
如果y[i]&&x[i],两个都可以输出?,其他x,y输出即可。
附上交互代码:
//g为从后往前 f为从前往后 是否合法
#include "paint.h"
#include<bits/stdc++.h>
using namespace std; const int N=2e5+;
const int K=;
bool g[N][K][],f[N][K][];//第i位 满足j段 并现在为0/1 白/黑
int x[N],y[N],last;
int tag[N];
char a[N];int b[N],sum1[N],sum2[N];
string res;
string solve_puzzle(std::string s, std::vector<int> c)
{
int n=s.length(),m=c.size();
for(int i=;i<=n;i++) a[i]=s[i-],sum1[i]+=sum1[i-]+(a[i]=='X'),sum2[i]+=sum2[i-]+(a[i]=='_');
for(int i=;i<=m;i++) b[i]=c[i-];
g[n+][m+][]=;
for(int i=n;i>=;i--)
{
for(int j=m+;j>=;j--)
{
if(a[i]^'X') g[i][j][]=g[i+][j][]|g[i+][j][];
if(j!=m+&&n-i+>=b[j]&&sum2[i+b[j]-]-sum2[i-]==) g[i][j][]=g[i+b[j]][j+][];
}
}
f[][][]=;
for(int i=;i<=n;i++)
{
for(int j=;j<=m;j++)
{
if(a[i]!='X') f[i][j][]=f[i-][j][]|f[i-][j][];
if(j&&i>=b[j]&&sum2[i]-sum2[i-b[j]]==) f[i][j][]=f[i-b[j]][j-][];
if(f[i][j][]&&g[i][j+][]) y[i]=;
if(f[i][j][]&&g[i+][j+][]) x[i-b[j]+]++,x[i+]--;
}
}
for(int i=;i<=n;i++)
{
x[i]+=x[i-];
if(a[i]=='.')
{
if(x[i]&&y[i]) res+='?';
else if(x[i]) res+='X';
else res+='_';
}else res+=a[i];
}
return res;
}
转载请声明!!!
IOI2016Day2. paint的更多相关文章
- 详解Paint的setXfermode(Xfermode xfermode)
一.setXfermode(Xfermode xfermode) Xfermode国外有大神称之为过渡模式,这种翻译比较贴切但恐怕不易理解,大家也可以直接称之为图像混合模式,因为所谓的“过渡”其实就是 ...
- android Canvas 和 Paint用法
自定义view里面的onDraw方法,在这里我们可以绘制各种图形,onDraw里面有两个API我们需要了解清楚他们的用法:Canvas 和 Paint. Canvas翻译成中文就是画布的意思,Canv ...
- [LeetCode] Paint Fence 粉刷篱笆
There is a fence with n posts, each post can be painted with one of the k colors. You have to paint ...
- [LeetCode] Paint House II 粉刷房子之二
There are a row of n houses, each house can be painted with one of the k colors. The cost of paintin ...
- [LeetCode] Paint House 粉刷房子
There are a row of n houses, each house can be painted with one of the three colors: red, blue or gr ...
- xp系统重绘边框线不显示(首次加载没有触发paint事件)
同样是,重绘边框事件,win7系统显示正常,而xp系统却不显示,这是什么原因造成的呢? 于是,小编开始百度,不停的查找原因,通过一番查找,小编也意外的收获了一些内容: 例如:窗口的拖动,放大,缩小,等 ...
- LeetCode Paint House II
原题链接在这里:https://leetcode.com/problems/paint-house-ii/ 题目: There are a row of n houses, each house ca ...
- LeetCode Paint House
原题链接在这里:https://leetcode.com/problems/paint-house/ 题目: There are a row of n houses, each house can b ...
- zjuoj 3773 Paint the Grid
http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3773 Paint the Grid Time Limit: 2 Secon ...
随机推荐
- SpringCloud的Archaius - 动态管理属性配置
参考链接:http://www.th7.cn/Program/java/201608/919853.shtml 一.Archaius是什么? Archaius用于动态管理属性配置文件. 参考自Gett ...
- Apache命令
参考于:http://www.jinbuguo.com/apache/menu22/programs/apxs.html 安装httpd-devel才有apxs
- Python之面向对象一
引子 小游戏:人狗大战 角色:人和狗 角色属性:姓名,血量,战斗力和性别(种类) 技能:打/咬 用函数实现人打狗和狗咬人的情形 def Dog(name,blood,aggr,kind): dog = ...
- jenkins配置findbugs失败---不要随便忽略警告!一个因为文件所有权引发的血案
一:背景交代 这两天组长让我这边搭一个持续集成环境.梳理了需求后,因为我们的项目都是maven项目,所以我选择了jenkins+外置maven(区别于直接从jenkins里面安装)的方案.(cento ...
- 面向对象中Object常用属性总结
学完Object属性,自己总结一些常用是Object常用属性. Object.prototype:属性表示Object的原型对象. 属性: Object.prototype.constructor:特 ...
- Centos系统运行nodejs
这里我们需要先搭建一下运行的环境,直接yum安装就可以了! [root@iZwz9f80ph5u8tlqp6pi9cZ ~]# yum -y install nodejs 这里我们的环境就搭好了!安装 ...
- c#:实现动态编译,并实现动态MultiProcess功能(来自python multiprocess的想法)
由于之前一直遇到一些关于并行进行数据处理的时效果往往不好,不管是c#还是java程序都是一样,但是在Python中通过multiprocess实现同样的功能时,却发现确实可以提高程序运行的性能,及服务 ...
- POJ-1251 Jungle Roads---MST裸题(需要编号)
题目链接: https://vjudge.net/problem/POJ-1251 题目大意: 首先给你一个图,需要你求出最小生成树,输入N个节点,用大写字母表示了节点,然后节点与节点之间有权值. 思 ...
- hdu1022 Train Problem I---模拟栈
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1022 题目大意: 车的进出站问题,先给出N个火车,再按序列一的方式进站,判断能否以序列二的方式出站,若 ...
- requests-post请求
post与get方法的区别在于post需要提交一些数据以备处理. 在requests里面非常简单,headers,data都是直接加进去就可以了 # requests.post提交表单# 有些网站使用 ...