uva1572——自组(World Final 2013,图论模型)
来源:互联网 发布:mac 固定便签在桌面上 编辑:程序博客网 时间:2024/05/18 19:39
///////////////////////////////////////////////////////////////////////////////////////////////////////
作者:tt2767
声明:本文遵循以下协议自由转载-非商用-非衍生-保持署名|Creative Commons BY-NC-ND 3.0
查看本文更新与讨论请点击:http://blog.csdn.net/tt2767
链接被删请百度: CSDN tt2767
///////////////////////////////////////////////////////////////////////////////////////////////////////
这题值得学习的几点:
1.输入匹配的代码十分优美!
2.把A+,A-映射成2n,2n+1做,然后通过(2n)^1 = 2n+1 , (2n+1)^1 = 2n 来反转,不得不说十分精妙!
题解:由于正方形是无限的,把要去连接编号与被链接的正方形上的其他可扩展编号看成节点,被链接的正方形看成边,寻找次有向图的环。
题目中的例子:
A- |->->->->->->->->->->A+|->->->->->->->->(A+,A+,00)
要连接的节点————两正方形连接点————被链接的正方形的其他节点
#include<cstdio>#include<cstring>int G[60][60];int vis[60];//把A+-变成2n和2n+1int ID(char x, char y);//这函数表示一个接口接到u上后成转换成的其他接口//利用(2n)^1 = 2n+1 , (2n+1)^1 = 2n 来反转void cont(char x1,char x2,char y1,char y2);bool dfs(int u);bool cyc();int main(){ int n; while(scanf("%d",&n) == 1 && n) { memset(G,'\0',sizeof(G)); memset(vis,0,sizeof(vis)); for(int i = 0 ; i < n ; i++) { char s[9]; scanf("%s",s); for(int j = 0 ; j < 4 ; j++) for(int k = 0 ; k < 4 ; k++) if(j != k) //对每个边都与其他非自身的边连接 cont(s[j*2],s[j*2+1],s[k*2],s[k*2+1]); } if(cyc()) puts("unbounded");//这个才是无限的。。。 else puts("bounded"); } return 0;}int ID(char x, char y){ return (x-'A')*2 + (y == '+' ? 0 : 1);}void cont(char x1,char x2,char y1,char y2){ if(x1 == '0' || y1 == '0') return ; int u = ID(x1,x2)^1 ; int v = ID(y1,y2); G[u][v]++;}bool dfs(int u){ vis[u] = -1; for(int i = 0 ; i < 52 ; i++) { if(G[u][i]) { if(vis[i] < 0) return true; else if(!vis[i] && dfs(i)) return true; } } vis[u] = 1; return false;}bool cyc(){ for(int i = 0 ; i < 52 ; i++) if(!vis[i] && dfs(i)) return true; return false;}
0 0
- uva1572——自组(World Final 2013,图论模型)
- Uva1572——Self-Assembly
- Uva1572 Self-Assembly 【建立图论模型拓扑排序】【例题6-19】
- uva1572 Self-Assembly 拓扑排序 提炼有向图模型
- 2013 World Final 排名
- 例题6-19 自组合 UVa1572
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 深入理解Java内存模型(六)——final
- 关于调试PLX9054的一些总结和经验
- iOS逆向笔记第一天
- 证明加载类的动作仅发生一次
- HDOJ2072单词数
- vpn下使用git无法克隆https项目的解决方案
- uva1572——自组(World Final 2013,图论模型)
- C#语法总结篇---写在开头的部分
- IOS开发之tableview单选
- 红与黑
- 批量插入数据 C# SqlBulkCopy使用
- hdoj-1213-How Many Tables【并查集】
- hdu 5285 wyh2000 and pupil(二染色)
- C#高级编程五十二天----有序列表
- gcc编译参数-fPIC的一些问题