UVA12267 Telephone Network
nb tea。
注意到如果两个需要相互接通的请求 \(a,b\) 在某一层分别接了上下两个开关,那么接下来它们永远也无法接通了,因为上下两个开关是相互独立的,不会出现上面的开关和下面的开关有连边的情况。
不妨先考虑每个请求如何接第 \(n-1\) 层开关。限制如下:
- 对于请求 \(i\in [0,2^{n-1})\),显然它们和请求 \(i+2^{n-1}\) 不能同时往上走或往下走,不然就会出现一个节点被两个请求占用的情况。
- \(a_j\) 和 \(b_j\) 走的方向要相同,即 \(b_j\) 走的方向不能与 \(a_j\) 相反。
- 请求不能同时往上或往下走。
有这么多限制,这就启发我们用图论的方法解决这道题目:一共有 \(2^{n+2}\) 个节点。第 \(i\in [0,2^n)\) 个节点表示左边第 \(i\) 个请求往上走;第 \(i\in[2^n,2^{n+1})\) 个节点表示左边第 \(i-2^n\) 个请求往下走;第 \(i\in [2^{n+1},3\times 2^n)\) 个节点表示右边第 \(i\) 个请求往上走;第 \(i\in[3\times 2^n,2^{n+2})\) 个节点同理。根据上述三种限制对于两个不能同时发生的事件,我们将其连一条边,最后二分图染色即可。因为保证有解所以不需要考虑无解的情况。
接第 \(n-1\) 层开关的方案有了之后,再类似地去考虑接第 \(n-2,n-3,\cdots,1\) 层开关即可。
时间复杂度 \(\mathcal{O}(Tn2^n)\)。
#include <bits/stdc++.h>
using namespace std;
#define mem(x,v) memset(x,v,sizeof(x))
const int N=16;
int t,n,m,x[1<<N],y[1<<N];
int cnt,vis[4<<N],col[4<<N],hd[4<<N],nxt[12<<N],to[12<<N];
void add(int u,int v){
nxt[cnt]=hd[u],hd[u]=cnt,to[cnt++]=v;
nxt[cnt]=hd[v],hd[v]=cnt,to[cnt++]=u;
}
void dfs(int id,int c){
vis[id]=1,col[id]=c;
for(int i=hd[id];i;i=nxt[i])if(!vis[to[i]])dfs(to[i],c^1);
}
void solve(){
cin>>n>>m;
for(int i=0;i<m;i++)scanf("%d%d",&x[i],&y[i]);
for(int i=n-1;~i;i--){
mem(vis,0),mem(col,0),mem(hd,0),cnt=0;
for(int j=0;j<m;j++)add(x[j],y[j]+(3<<n)),add(x[j]+(1<<n),y[j]+(2<<n));
for(int j=0;j<1<<n;j++)add(j,j+(1<<n)),add(j+(2<<n),j+(3<<n));
for(int j=0;j<1<<n;j++)if((j>>i)&1)
add(j,j-(1<<i)),add(j+(1<<n),j-(1<<i)+(1<<n)),
add(j+(2<<n),j+(2<<n)-(1<<i)),
add(j+(3<<n),j+(3<<n)-(1<<i));
for(int j=0;j<4<<n;j++)if(!vis[j])dfs(j,0);
for(int j=0;j<m;j++){
if(col[x[j]])x[j]-=(x[j]>>i&1)<<i;
else x[j]+=(!(x[j]>>i&1))<<i;
if(col[y[j]+(2<<n)])y[j]-=(y[j]>>i&1)<<i;
else y[j]+=(!(y[j]>>i&1))<<i;
}
}
for(int i=0;i<m;i++)cout<<x[i]<<(i==m-1?'\n':' ');
}
int main(){
cin>>t;
while(t--)solve();
return 0;
}
UVA12267 Telephone Network的更多相关文章
- Overlay network 覆盖网络
From Wikipedia, the free encyclopedia An overlay network is a computer network that is built on top ...
- UVA 1456 六 Cellular Network
Cellular Network Time Limit:3000MS Memory Limit:0KB 64bit IO Format:%lld & %llu Submit S ...
- Lists of network protocols
https://en.wikipedia.org/wiki/Lists_of_network_protocols Protocol stack: List of network protocol st ...
- word20161217
p-node / p 节点 package / 程序包 packet / 数据包 packet assembler/disassembler, PAD / 分组拆装器 packet header / ...
- Android IOS WebRTC 音视频开发总结(十)-- webrtc入门002
继续上一篇中未翻译完成的部分,主要包括下面三个部分: 1,扩展:WebRTC多方通话. 2,MCU Multipoint Control Unit. 2, 扩展:VOIP,电话,消息通讯. 注意:翻译 ...
- url中的scheme
iPhone上URL Schemes的作用为应用程序提供了一个其他应用程序或者safari可以启动他的方法. --http://blog.sina.com.cn/s/blog_5673c12f0100 ...
- openerp - asterisk connector(转载)
原文:http://www.akretion.com/open-source-contributions/openerp-asterisk-voip-connector OpenERP - Aster ...
- CCNA第一讲笔记
园区网:一组连续的局域网(校园网.企业内部网) 园区网拓扑: 一层楼的PC连接到一台交换机(同一层的PC可以互联):一栋楼的每层的交换机连接到同一台交换机(整栋楼的PC可以互联):每栋楼的交换机连接到 ...
- PSTN
PSTN ( Public Switched Telephone Network )定义:公共交换电话网络,一种常用旧式电话系统.即我们日常生活中常用的电话网.工作原理 公共交换电话网络是一种全球语音 ...
随机推荐
- 第四代富士X100F操作学习
前言 本文为自己通过B站的UP主[阿布垃机手册]整理.原视频地址:[阿布垃机手册][布瞎BB]富士 X100F 相机外部按键 拍人像自己的设置 [X100F相机光圈大小支持F2到F16+Auto]光圈 ...
- Scrum Meeting 0505
零.说明 日期:2021-5-5 任务:简要汇报两日内已完成任务,计划后两日完成任务 一.进度情况 组员 负责 两日内已完成的任务 后两日计划完成的任务 qsy PM&前端 完成邮箱注册页面功 ...
- AIApe问答机器人Scrum Meeting 4.27
Scrum Meeting 3 日期:2021年4月27日 会议主要内容概述:汇报两日工作. 一.进度情况 组员 负责 两日内已完成的工作 后两日计划完成的工作 工作中遇到的困难 李明昕 后端 Tas ...
- [no code][scrum meeting] Beta 11
$( "#cnblogs_post_body" ).catalog() 例会时间:5月26日11:30,主持者:肖思炀 下次例会时间:5月27日11:30,主持者:乔玺华 一.工作 ...
- 常用Java API:HashMap 和 TreeMap
摘要 本文主要介绍Map接口下的HashMap和TreeMap. HashMap HashMap是基于哈希表的 Map 接口的实现,是无序的 clear()//清空. containsKey(Obje ...
- 2021CCPC河南省省赛
大一萌新,第一次打比赛,虽然是线下赛,但送气球的环节还是很赞的! 这里主要是补一下自己的弱项和考试时没有做出来的题目. 1002(链接之后再放,官方还没公开题目...) 先说一下第二题,这个题一看就是 ...
- linux环境下redis安装(redis伪集群搭建)
redis在linux环境下搭建 1.创建目录 [root@192 local]# mkdir /usr/local/redis 2.下载redis,并解压 [root@192 local]# wge ...
- native连接远程mysql数据库
1.环境 CentOS7.mysqld 8.0.19 2.登录数据库 #mysql -u root -p 2.修改root登录地址为%(任何IP) mysql> update user set ...
- k8s入坑之路(14)scheduler调度 kubelet管理及健康检查 更新策略
kubelet 主要功能 Pod 管理 在 kubernetes 的设计中,最基本的管理单位是 pod,而不是 container.pod 是 kubernetes 在容器上的一层封装,由一组运行在同 ...
- SpringCloud 2020.0.4 系列之 Sleuth + Zipkin
1. 概述 老话说的好:安全不能带来财富,但盲目的冒险也是不可取的,大胆筹划,小心实施才是上策. 言归正传,微服务的特点就是服务多,服务间的互相调用也很复杂,就像一张关系网,因此为了更好的定位故障和优 ...