【BZOJ3003】LED BFS+状压DP
【BZOJ3003】LED
Description
Input
Output
Sample Input
10 8 2
1 2 3 5 6 7 8 9
3 5
3 2 1
1 2
3
Sample Output
-1
【数据规模】
对于100%的数据,T≤10,N≤10000,K≤10,L≤100,1≤A_i≤N。
题解:一开始想网络流想了半天。。。结果是错的。
第一步很常用也很关键,我们将原序列差分,然后就变成了只有2k个关键点需要染黑,而每个操作可以看成是将两个距离为L的格子同时反色。这个过程比较类似于一个最短路的过程,我们将一个关键点染色,此时出现了一个多余的点,我们再将多余点不断反色直到走到了另一个关键点,此时我们可以看做这两个关键点成功配对,而代价就是从这个点走到另一个点的最短路。所以我们先预处理出任意两个关键点之间的最短路,然后DP。
设f[S]表示已经配对的点的状态为S的最小代价。转移时,我只需要们枚举S中最后那个点和谁配对即可。
#include <cstdio>
#include <cstring>
#include <iostream>
#include <queue>
#include <algorithm>
using namespace std;
int n,m,K,L;
bool vis[10010];
int op[30],w[30],v[110],dis[10010],f[30][30],g[1<<20],Log[1<<20];
queue<int> q;
inline int rd()
{
int ret=0,f=1; char gc=getchar();
while(gc<'0'||gc>'9') {if(gc=='-') f=-f; gc=getchar();}
while(gc>='0'&&gc<='9') ret=ret*10+(gc^'0'),gc=getchar();
return ret*f;
}
inline void work()
{
n=rd(),K=rd(),L=rd(),m=0;
memset(f,0x3f,sizeof(f)),memset(g,0x3f,sizeof(g));
int i,j,a,u;
for(i=1;i<=K;i++)
{
op[i]=rd();
for(j=1;j<i;j++) if(op[j]==op[i]) break;
if(j==i) vis[op[i]]^=1,vis[op[i]+1]^=1;
}
for(i=1;i<=n+1;i++) if(vis[i]) w[m++]=i,vis[i]=0;
for(i=1;i<=L;i++) v[i]=rd();
sort(w,w+m);
for(i=0;i<m;i++) Log[1<<i]=i;
for(i=0;i<m;i++)
{
memset(dis,0x3f,sizeof(dis));
q.push(w[i]),dis[w[i]]=0;
while(!q.empty())
{
u=q.front(),q.pop();
for(j=1;j<=L;j++)
{
if(u+v[j]<=n+1&&dis[u+v[j]]==0x3f3f3f3f) dis[u+v[j]]=dis[u]+1,q.push(u+v[j]);
if(u-v[j]>=1&&dis[u-v[j]]==0x3f3f3f3f) dis[u-v[j]]=dis[u]+1,q.push(u-v[j]);
}
}
for(j=0;j<m;j++) if(i!=j) f[i][j]=dis[w[j]];
}
g[0]=0;
for(i=1;i<(1<<m);i++)
{
a=Log[i&-i];
for(j=a+1;j<m;j++) if((i>>j)&1) g[i]=min(g[i],g[i^(1<<j)^(1<<a)]+f[j][a]);
}
printf("%d\n",(g[(1<<m)-1]==0x3f3f3f3f)?-1:g[(1<<m)-1]);
}
int main()
{
int T=rd();
while(T--) work();
return 0;
}//2 10 8 2 1 2 3 5 6 7 8 9 3 5 3 2 1 1 2 3
//1 10 3 2 1 1 10 10 8
【BZOJ3003】LED BFS+状压DP的更多相关文章
- #12【BZOJ3003】LED BFS+状压DP
题解: 看到区间修改先想一下差分 这题用差分是为了分析问题 现在的问题就变成了 原序列全为0,要使得特定的k个点变为1,每个操作改变x,y+1 然后我们会发现 对于二元组a,b我们要修改它,实际上是在 ...
- hdu 4856 Tunnels (bfs + 状压dp)
题目链接 The input contains mutiple testcases. Please process till EOF.For each testcase, the first line ...
- HDU-4856 Tunnels (BFS+状压DP)
Problem Description Bob is travelling in Xi’an. He finds many secret tunnels beneath the city. In hi ...
- 孤岛营救问题(BFS+状压DP)
孤岛营救问题 https://www.luogu.org/problemnew/show/P4011 用状压DP标记拿到钥匙的数量 #include<iostream> #include& ...
- QDUOJ 来自xjy的签到题(bfs+状压dp)
来自xjy的签到题 Description 爱丽丝冒险来到了红皇后一个n*n大小的花园,每个格子由'.'或'#'表示,'.'表示爱丽丝可以到达这个格子,‘#’表示爱丽丝不能到达这个格子,爱丽丝每1 ...
- HDU-3681-Prison Break(BFS+状压DP+二分)
Problem Description Rompire is a robot kingdom and a lot of robots live there peacefully. But one da ...
- 【BZOJ 3049】【USACO2013 Jan】Island Travels BFS+状压DP
这是今天下午的互测题,只得了60多分 分析一下错因: $dis[i][j]$只记录了相邻的两个岛屿之间的距离,我一开始以为可以,后来$charge$提醒我有可能会出现来回走的情况,而状压转移就一次,无 ...
- CodeForces 907E Party(bfs+状压DP)
Arseny likes to organize parties and invite people to it. However, not only friends come to his part ...
- HDU 3247 Resource Archiver (AC自动机+BFS+状压DP)
题意:给定 n 个文本串,m个病毒串,文本串重叠部分可以合并,但合并后不能含有病毒串,问所有文本串合并后最短多长. 析:先把所有的文本串和病毒都插入到AC自动机上,不过标记不一样,可以给病毒标记-1, ...
随机推荐
- LintCode - Copy List with Random Pointer
LintCode - Copy List with Random Pointer LintCode - Copy List with Random Pointer Web Link Descripti ...
- 用python批量执行VBA代码
先说下背景环境 1. 公司需要问卷调查,有两份问卷, 1)是spss问卷,2)是excel问卷.spss问卷数据不全,但有各种标签, excel呢, 生成的数据直接把选项变成了值 2. 现在需要把ex ...
- 【转】【C++】C++ 中的线程、锁和条件变量
线程 类std::thread代表一个可执行线程,使用时必须包含头文件<thread>.std::thread可以和普通函数,匿名函数和仿函数(一个实现了operator()函数的类)一同 ...
- webBrowser1.Document.Cookie取不到HttpOnly的Cookie,取Cookie不完整【转】
在做数据采集时,有些网站需要输入验证码,但各网站验证码都不同,不可能有完美的识别验证码的代码,所以我也没去研究,我所采取的方案是:在winform里通过WebBrowser调用网页先手动登录系统,然后 ...
- 多种方法实现div两列等高(收集整理)
HTML骨架 <div id="header">头部</div> <div id ="container"> <div ...
- 关于C++中using namespace std
原文链接:http://www.kuqin.com/language/20080107/3532.html <iostream>和<iostream.h>是不一样,前者没有后缀 ...
- ActiveMQ-5.13.0集群
ActiveMQ集群介绍 ActiveMQ具有强大和灵活的集群功能,但在使用的过程中会发现很多的缺点,ActiveMQ的集群方式主要由两种:Master-Slave(ActiveMQ5.8版本已不可用 ...
- 分配All AD User到SharePoint Group中
使用名称为“NT AUTHORITY\Authenticated Users”
- SharePoint 2010用“localhost”方式访问网站,File not found问题处理方式
场景:本地服务器上,用“localhost”方式访问网站:在某网站集(Site Collection)下的子网站(Sub Site)中,点击网站权限菜单(Site permissions)等关于调用L ...
- ubuntu设置中文拼音输入法
转载 http://www.cnblogs.com/zhj5chengfeng/archive/2013/06/23/3150620.html