题目链接

题解

设\(b[i]=a[i]\ xor\ a[i+1]\)

我们可以发现,修改只会改变\(b[l-1]\)和\(b[r]\)

然后发现\(b[i]=1\)的点最多\(2*k\)个

状压\(dp\)

Code

void bfs(int s) {
memset(vis, 0, sizeof(vis));
vis[s] = 1; q.push(make_pair(s, 0));
while (!q.empty()) {
int u = q.front().first, d = q.front().second; q.pop();
if (b[u]) g[num[s]][num[u]] = d;
for (int i = 1; i <= l; i++) {
if (u + a[i] <= n && !vis[u + a[i]])
vis[u + a[i]] = 1, q.push(make_pair(u + a[i], d + 1));
if (u - a[i] >= 0 && !vis[u - a[i]])
vis[u - a[i]] = 1, q.push(make_pair(u - a[i], d + 1));
}
}
}
void solve() {
n = gi<int>(), k = gi<int>(), l = gi<int>();
memset(b, 0, sizeof(b)); tot = 0;
for (int i = 1; i <= k; i++) b[gi<int>()] = 1;
for (int i = 0; i <= n; i++)
if (b[i] ^= b[i + 1])
num[i] = tot++;
for (int i = 1; i <= l; i++) a[i] = gi<int>();
int lim = 1 << tot;
memset(g, 0x3f, sizeof(g));
memset(f, 0x3f, sizeof(f));
for (int i = 0; i <= n; i++)
if (b[i]) bfs(i);
f[0] = 0;
for (int i = 1, p; i < lim; i++) {
p = 0; while (!(i & 1 << p)) p++;
for (int j = p + 1; j < tot; j++)
if (i & 1 << j)
f[i] = min(f[i], f[i ^ 1 << p ^ 1 << j] + g[j][p]);
}
printf("%d\n", f[lim - 1] > inf ? -1 : f[lim - 1]);
return ;
}

bzoj3508: 开灯的更多相关文章

  1. BZOJ3508 开灯 & [校内NOIP2018模拟20181027] 密码锁

    Time Limit: 10 Sec Memory Limit: 128 MB Description xx作为信息学界的大神,拥有众多的粉丝.为了感谢众粉丝的爱戴,xx决定举办一场晚会.为了气派,x ...

  2. 【BZOJ3508】开灯

    [BZOJ3508]开灯 题面 bzoj 题解 其实变为目标操作和从目标操作变回来没有区别,我们考虑从目标操作变回来. 区间整体翻转(\(\text{Xor}\;1\))有点难受,我们考虑将这个操作放 ...

  3. c语言实现开灯问题

    开灯问题: 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依 ...

  4. Jquery开灯关灯效果

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  5. 9509 开灯(dfs)

    9509 开灯 时间限制:1000MS  内存限制:65535K提交次数:0 通过次数:0 题型: 编程题   语言: G++;GCC Description 有16的开关分别控制16盏灯,开关排列成 ...

  6. NYOJ 题目77 开灯问题(简单模拟)

    开灯问题 时间限制:3000 ms  |            内存限制:65535 KB 难度:1           描述 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 ...

  7. 洛谷 P1876 开灯(思维,枚举,规律题)

    P1876 开灯 题目背景 该题的题目是不是感到很眼熟呢? 事实上,如果你懂的方法,该题的代码简直不能再短. 但是如果你不懂得呢?那...(自己去想) 题目描述 首先所有的灯都是关的(注意是关!),编 ...

  8. 【Luogu1876】开灯(数论)

    [Luogu1876]开灯(数论) 题面 题目描述 首先所有的灯都是关的(注意是关!),编号为1的人走过来,把是一的倍数的灯全部打开,编号为二的的把是二的倍数的灯全部关上,编号为3的人又把是三的倍数的 ...

  9. POJ 1218 THE DRUNK JAILER(类开灯问题,完全平方数)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=2188 题目大意:n为5-100之间的一个数,代表有多少间牢房,刚开始所有房间打开,第一轮2的倍数的房间 ...

随机推荐

  1. popcorn-js视频Video框架简单用法

    <div> <video class="video" id="ourvideobig" preload="auto" co ...

  2. Rsync同步过程中遇到的常见问题

    一.Rsync服务介绍 Rsync属于一款实现全量及增量同步数据的软件工具,适用于unix/linux/windows等多种操作系统平台. Rsync软件能实现本地复制,远程复制,或者远程守护进程方式 ...

  3. Hackthebox--------irked

    菜鸟一枚,大佬轻喷!! Web页面就一张表情图和一句IRC is almost working!(是irc服务么??!!) 查看图片信息,貌似图片没这么简单.... 果然没这么简单,不行,得想办法得到 ...

  4. C++ 类再探

    关于类的一些遗漏的点. #include <iostream> #include <typeinfo> #include <string> using namesp ...

  5. leetcode-8.atoi · string *

    题面 原题挺长的,还是英文,就不抄了,

  6. Memory Network

    转自:https://www.jianshu.com/p/e5f2b20d95ff,感谢分享! 基础Memory-network 传统的RNN/LSTM等模型的隐藏状态或者Attention机制的记忆 ...

  7. linux修改文件系统注册设备

  8. 安装 ALC 解决 centos8 不能播放多媒体的问题

    装完centos8 后,发现看不到视频,听不到音乐,连web在线听音乐也不行.通过安装ALC可以解决. 1.三步安装VLC 这是 centos8 的安装包,曾使用 8 之前的版本安装是不成功的 sud ...

  9. C++——数组形参退化为指针

    数组做形参退化为指针 如果数组作为函数参数,则数组形参会退化为指针,以下代码在编译器看来是等价的 ]); ]); void fun3(int a[]); void fun4(int *a); #inc ...

  10. 【数据库】通过触发器实现审计日志记录-demo篇

      触发器实现审计日志记录(记录增.删.改) #创建测试表 CREATE TABLE COMPANY( ID INT PRIMARY KEY NOT NULL, NAME TEXT NOT NULL, ...