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的更多相关文章

  1. Overlay network 覆盖网络

    From Wikipedia, the free encyclopedia An overlay network is a computer network that is built on top ...

  2. UVA 1456 六 Cellular Network

    Cellular Network Time Limit:3000MS     Memory Limit:0KB     64bit IO Format:%lld & %llu Submit S ...

  3. Lists of network protocols

    https://en.wikipedia.org/wiki/Lists_of_network_protocols Protocol stack: List of network protocol st ...

  4. word20161217

    p-node / p 节点 package / 程序包 packet / 数据包 packet assembler/disassembler, PAD / 分组拆装器 packet header / ...

  5. Android IOS WebRTC 音视频开发总结(十)-- webrtc入门002

    继续上一篇中未翻译完成的部分,主要包括下面三个部分: 1,扩展:WebRTC多方通话. 2,MCU Multipoint Control Unit. 2, 扩展:VOIP,电话,消息通讯. 注意:翻译 ...

  6. url中的scheme

    iPhone上URL Schemes的作用为应用程序提供了一个其他应用程序或者safari可以启动他的方法. --http://blog.sina.com.cn/s/blog_5673c12f0100 ...

  7. openerp - asterisk connector(转载)

    原文:http://www.akretion.com/open-source-contributions/openerp-asterisk-voip-connector OpenERP - Aster ...

  8. CCNA第一讲笔记

    园区网:一组连续的局域网(校园网.企业内部网) 园区网拓扑: 一层楼的PC连接到一台交换机(同一层的PC可以互联):一栋楼的每层的交换机连接到同一台交换机(整栋楼的PC可以互联):每栋楼的交换机连接到 ...

  9. PSTN

    PSTN ( Public Switched Telephone Network )定义:公共交换电话网络,一种常用旧式电话系统.即我们日常生活中常用的电话网.工作原理 公共交换电话网络是一种全球语音 ...

随机推荐

  1. 【数据结构与算法Python版学习笔记】树——二叉树的应用:解析树

    解析树(语法树) 将树用于表示语言中句子, 可以分析句子的各种语法成分, 对句子的各种成分进行处理 语法分析树 程序设计语言的编译 词法.语法检查 从语法树生成目标代码 自然语言处理 机器翻译 语义理 ...

  2. CSP-S 2021 退役记

    写的比较草率,但的确是真实感受. 10.23 回寝室前敲了一个 dinic 板子,觉得不会考... 10.24 8:00 起床,还好今天宿管不在,可以起的晚一点. 吃了早饭来机房颓废. 10:00 似 ...

  3. Java代理:静态代理、JDK动态代理和CGLIB动态代理

    代理模式(英语:Proxy Pattern)是程序设计中的一种设计模式.所谓的代理者是指一个类别可以作为其它东西的接口.代理者可以作任何东西的接口:网络连接.存储器中的大对象.文件或其它昂贵或无法复制 ...

  4. 利用Nginx搭建Ambari本地安装源

    1.下载本地源包https://docs.hortonworks.com/HDPDocuments/Ambari-2.7.3.0/bk_ambari-installation/content/ch_o ...

  5. linux shell脚本中的开头#!/bin/bash的含义

    对于linux上需要执行 的shell脚本,通常第一行的内容是 #!/bin/bash 当然有很多时候不规范的写法可以忽略掉这一句,执行起来好像也是ok,结果没什么不一样 .. 这只是因为在我们常用 ...

  6. songwenxin

    # -*- coding: utf-8 -*- import wx from modelmngr_frame import MyFrame1 ############################# ...

  7. linux 的 逻辑卷管理

    lvm 逻辑卷管理器 关于逻辑卷管理lvm的一些操作 新建磁盘 sdcfdisk /dev/sdc 创建分区,更改分区id 为8e,改变分区类型为 lvm linux 创建物理卷与pv相关 pvcre ...

  8. Device /dev/sdb excluded by a filter

    原因是添加的磁盘是在另一个虚拟机中新建的,已经有了分区表,现在的虚拟机并不能识别磁盘的分区表,运行parted命令重做分区表,中途需要输入三次命令(mklabel msdos -> yes-&g ...

  9. 更优于 Shellinabox 的 web shell 工具 -- ttyd

    ttyd 是一个运行在服务端,客户端通过web浏览器访问从而连接后台 tty (pts伪终端)接口的程序,把 shell 终端搬到 web 浏览器中. WebSocket WebSocket 是 HT ...

  10. [mysql课程作业]我的大学|作业

    第八周周五 1.将xs表中王元的专业改为"智能建筑". # update xs set 专业名='智能建筑' where 姓名='王元'; # select * from xs w ...