【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, ...
随机推荐
- Entity Framework应用:管理并发
理解并发 并发管理解决的是允许多个实体同时更新,实际上这意味着允许多个用户同时在相同的数据上执行多个数据库操作.并发是在一个数据库上管理多个操作的一种方式,同时遵守了数据库操作的ACID属性(原子性. ...
- python_matplotlib知识点总结
文作为学习过程中对matplotlib一些常用知识点的整理,方便查找. 强烈推荐ipython无论你工作在什么项目上,IPython都是值得推荐的.利用ipython --pylab,可以进入PyLa ...
- 从零开始,制定PHP学习计划
7月份学习计划1-15 搭建开发环境.做个小demo 增删改查.Mysql数据库16-30号 架构设计.服务器管理.版本控制 8月份正式入手项目jquery脚本学习Thinksns开源学习.核心业务学 ...
- linux -- 进程的查看、进程id的获取、进程的杀死
进程查看 ps ax : 显示当前系统进程的列表 ps aux : 显示当前系统进程详细列表以及进程用户 ps ax|less : 如果输出过长,可能添加管道命令 less查看具体进程, 如:ps a ...
- samtools flags 的含义
对于双端比对的数据,生成的BAM文件中,R1端序列和R2端序列的标识符是一样的,之前一直不知道如何根据bam文件区分哪条序列是R1端,哪条序列是R2端,昨天仔细研究了一下,原来代表R1端和R2端的信息 ...
- js数组去重。。(拷的别人代码)
function unique(arr) { var result = [], hash = {}; for (var i = 0, elem; (elem = arr[i]) != null; i+ ...
- C语言对文件的操作函数用法详解1
在ANSIC中,对文件的操作分为两种方式,即: 流式文件操作 I/O文件操作 一.流式文件操作 这种方式的文件操作有一个重要的结构FILE,FILE在stdio.h中定义如下: typedef str ...
- [spring] 对实体 "characterEncoding" 的引用必须以 ';' 分隔符结尾
org.springframework.beans.factory.xml.XmlBeanDefinitionStoreException: Line 26 in XML document from ...
- mybatis由浅入深day01_6SqlMapConfig.xml(6.2settings全局参数配置_6.3typeAliases(类型别名)_6.4typeHandlers(类型处理器)_6.5mappers(映射配置))
6 SqlMapConfig.xml mybatis的全局配置文件SqlMapConfig.xml,配置内容和顺序如下: properties(属性) settings(全局配置参数) typeAli ...
- Swift学习笔记之--类和对象
通过在 class后接类名称来创建一个类.在类里边声明属性与声明常量或者变量的方法是相同的,唯一的区别的它们在类环境下.同样的,方法和函数的声明也是相同的写法 class Shape { func s ...