poj1308 并查集
比较恶心
- 1: 0 0 空树是一棵树
- 2: 1 1 0 0 不是树
- 3: 1 2 1 2 0 0 不是树...
- 4: 1 2 2 3 4 5 不是树 森林不算是树
- 5: 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 1 错
- 6: 1 2 2 1 0 0 也是错误的
- #include<stdio.h>
- #include<string.h>
- int pa[],a[],b[],n,in[],map[],hash[];
- void init()
- {
- for(int i=;i<=n;i++)
- {
- pa[i]=i;
- }
- }
- int find(int x)
- {
- if(x!=pa[x])
- pa[x]=find(pa[x]);
- return pa[x];
- }
- int main()
- {
- int i,j,flag,ff=;
- while(scanf("%d%d",&a[],&b[])!=EOF)
- {
- j=;
- memset(hash,,sizeof(hash));
- memset(map,,sizeof(map));
- memset(in,,sizeof(in));
- if(!hash[a[]])
- map[j++]=a[];
- if(!hash[b[]])
- map[j++]=b[];
- if(a[]==&&b[]==)
- {
- printf("Case %d is a tree.\n",++ff);
- continue;
- }
- n=;
- flag=;
- if(a[]<&&b[]<)
- break;
- in[a[]]++,in[b[]]++;
- if(a[] > n) n = a[];
- if(b[] > n) n = b[];
- i=;
- while()
- {
- i++;
- scanf("%d %d",&a[i],&b[i]);
- if(a[i]==&&b[i]==)
- break;
- if(!hash[a[i]])
- {
- hash[a[i]]=;
- map[j++]=a[i];
- }
- if(!hash[b[i]])
- {
- map[j++]=b[i];
- hash[b[i]]=;
- }
- if(a[i] > n) n = a[i];
- if(b[i] > n) n = b[i];
- }
- int num=j;
- //for(j=0;j<num;j++)
- // printf("%d ",map[j]);
- //printf("\n");
- int len=i;
- init();
- for(i=;i<len;i++)
- {
- int x,y;
- x=find(a[i]);
- y=find(b[i]);
- if(x!=y)
- {
- pa[x]=y;
- }
- else
- flag=;
- }
- int ans=;
- for(i=;i<num;i++)
- {
- if(pa[map[i]]==map[i])
- {
- ans++;
- }
- }
- if(ans>)
- flag=;
- if(flag)
- printf("Case %d is a tree.\n",++ff);
- else
- printf("Case %d is not a tree.\n",++ff);
- }
- }
poj1308 并查集的更多相关文章
- poj1308(并查集)
题目链接:http://poj.org/problem;jsessionid=436A34AE4BE856FB2DF9B264DCA9AA4E?id=1308 题意:给定一些边让你判断是否构成数. 思 ...
- 并查集——poj1308(并查集延伸)
题目链接:Is It A Tree? 题意:给你一系列形如u v的点对(u v代表一条由u指向v的有向边),请问由给你的点构成的图是不是一棵树? 树的特征:①每个节点(除了根结点)只有一个入度:②只有 ...
- POJ1308:Is It A Tree?(并查集)
Is It A Tree? 题目链接:http://poj.org/problem?id=1308 Description: A tree is a well-known data structure ...
- POJ1308/HDU1325/NYOJ129-Is It A Tree?,并查集!
Is It A Tree? Time Limit: 1000MS Memory Limit: 10000K Total Submissions: 28838 Accepted: 9843 -& ...
- POJ-1308 Is It A Tree?(并查集判断是否是树)
http://poj.org/problem?id=1308 Description A tree is a well-known data structure that is either empt ...
- 【转】并查集&MST题集
转自:http://blog.csdn.net/shahdza/article/details/7779230 [HDU]1213 How Many Tables 基础并查集★1272 小希的迷宫 基 ...
- BZOJ 4199: [Noi2015]品酒大会 [后缀数组 带权并查集]
4199: [Noi2015]品酒大会 UOJ:http://uoj.ac/problem/131 一年一度的“幻影阁夏日品酒大会”隆重开幕了.大会包含品尝和趣味挑战两个环节,分别向优胜者颁发“首席品 ...
- 关押罪犯 and 食物链(并查集)
题目描述 S 城现有两座监狱,一共关押着N 名罪犯,编号分别为1~N.他们之间的关系自然也极不和谐.很多罪犯之间甚至积怨已久,如果客观条件具备则随时可能爆发冲突.我们用"怨气值"( ...
- 图的生成树(森林)(克鲁斯卡尔Kruskal算法和普里姆Prim算法)、以及并查集的使用
图的连通性问题:无向图的连通分量和生成树,所有顶点均由边连接在一起,但不存在回路的图. 设图 G=(V, E) 是个连通图,当从图任一顶点出发遍历图G 时,将边集 E(G) 分成两个集合 T(G) 和 ...
随机推荐
- IOS Orientation, 想怎么转就怎么转~~~
此博文主要针对IOS应用, 是屏幕旋转相关问题的一个总结. 主要内容有: IOS5,6,7不同版的适配. 强制旋转和自动旋转. 博客: http://www.cnblogs.com/jhzhu 邮箱: ...
- jquery 实现邮箱输入自动提示功能:(一)
记得去年做某个项目的时候,用到了邮箱输入自动提示功能,于是网上搜了一下,发现了这个写得不错,现在回想起来,转载一下,方便查阅. 邮箱的广泛使用得益于它的免费,因此很多网站在注册的时候都会直接使用邮箱作 ...
- NGUI 3.x 练习
一.常用快捷键 Alt+Shitf+W 创建一个新的 Widget Alt+Shift+S 创建一个新的 Sprite Alt+Shift+L 创建一个新的 Label Alt+Shift+T 创建一 ...
- java 20 - 8 字节流的文件复制以及汉字在计算机中的存储方式
复制文本文件:把当前目录下的FileIntputStream.java文件里面的内容复制到当前目录的b.txt文件中 分析: 数据源: FileIntputStream.java -- 读取数据 -- ...
- xshell5 启动显示 mfc110.dll msvcp110.dll 未找到问题 解决办法
1. 安装 Visual C++ Redistributable for Visual Studio 2012 x86版本 注意: 一定要安装x86版本.(xshell5是32位的程序) 微软的官方下 ...
- Android SQLite (三 ) 全面详解(一)
官网 SQLite是一款轻型的数据库,是关系型数据库(RDBMS)管理系统,它包含在一个相对小的C库中.目前在很多嵌入式产品中使用了它,它占用资源非常 的低,在嵌入式设备中,可能只需要几百K的内存就够 ...
- 一、IOS运行原理
1.首先执行main函数 2.执行UIPaalicationMain函数 3.UIApplication函数内部 1>创建一个UIApplication实例.这个UIApplication对象是 ...
- Maven 其他功能
测试:指定测试哪些测试类,指定哪些测试类不测试,可以使用通配符 使用 Hudson 进行持续集成 持续集成:快速且高频率地自动构建项目的所有源码,并为项目成员提供丰富的反馈信息 一个典型的持续集成场景 ...
- 15Mybatis_输出类型
输出类型分为两种:1.resultType 和 2.resultMap 接下来先讲解resultType: 使用resultType进行输出映射,只有查询出来的列名和 ...
- 使用ConfigurationManager类读写配置文件
使用ConfigurationManager类 读写配置文件app.config,以下为代码: view plaincopy to clipboard print? using System; usi ...