【HDU1325】Is It A Tree?(并查集基础题)

有以下坑点:

1.结束输入不一定-1,题目中的叙述只是说所有权值都为正值。

2.是否构成一棵树不能只判断是否只有一个根节点,没有环路,而且还需要判断每个节点的入度一定是1,不然就不是一棵树。

(无环路也可用树的性质:结点数 = 边树 + 1 来取代)

 

 1 #include <iostream>
 2 #include <cstdlib>
 3 #include <cstring>
 4 #include <cctype>
 5 #include <cmath>
 6 #include <string>
 7 #include <cstdio>
 8 #include <algorithm>
 9 #include <numeric>
10 using namespace std;
11 
12 const int maxn = 25;
13 
14 int  father[maxn];
15 int  eage[maxn];
16 bool vis[maxn], flag = 0;
17 int sum = 0;
18 
19 int getFather (int x) {
20     while (father[x] != x) {
21         x = father[x];
22     }
23     return x;
24 }
25 
26 void Union (int p, int q) {
27     int x = getFather (p);
28     int y = getFather (q);
29     if (x != y) {
30         father[y] = x;
31         sum ++;
32     } else {
33         flag = 0;
34     }
35 }
36 
37 int main () {
38     int x, y, cur = 0;
39     while (cin >> x >> y) {
40         if (x < 0 && y < 0) break;
41         if (x == 0 && y == 0) {
42             printf("Case %d is a tree.\n", ++ cur);
43             continue;
44         } else {
45             flag = 1;
46             memset(vis, 0, sizeof(vis));
47             memset(eage, 0, sizeof(eage));
48             for (int i = 0; i < maxn; ++ i) {
49                 father[i] = i;
50             }
51             vis[x] = vis[y] = 1;
52             Union(x, y);
53             eage[y] ++;
54             while (cin >> x >> y) {
55                 if (x + y == 0) break;
56                 vis[x] = vis[y] = 1;
57                 Union(x, y);
58                 eage[y] ++;
59             }
60             sort(eage, eage + maxn, greater<int>());
61             int xx = 0;
62             if (eage[0] > 1) flag = 0;
63             for (int i = 1; i < maxn; ++ i) {
64                 if (vis[i] && father[i] == i) {
65                     xx ++;
66                     if (xx > 1) {flag = 0; break;}
67                 }
68             }
69             /*for (int i = 1 ; i < maxn; ++ i) {
70                 cout << vis[i] <<  " " ;
71             }*/
72 
73             if (flag) printf("Case %d is a tree.\n", ++ cur);
74             else printf("Case %d is not a tree.\n", ++ cur);
75         }
76     }
77     return 0;
78 }

转载于:https://www.cnblogs.com/Destiny-Gem/p/3861247.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/432431.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql 逗号金额比较,如何使用MySQL比较两个逗号分隔的字符串列表

我使用了一个名为“ containsAll()”的Java方法来检查ArrayLists是否具有共同的内容.假设我在MySQL表中有一个列表A(一行)和其他几个列表(在“名称”列中,逐行).所有列表均由逗号分隔的字符串(列表中至少一个字符串)组成-名称或其他名称.现在,我想检查列表A中的所有字符串是否都…

MFC序列化(serial)简单例子

我们保存一些文本内容可以很简单的保存成一个文件就行了.但如果要把一些类对象信息保存起来,然后读取时用那些信息初始化一个类对象就比较复杂了.MFC提供了一个叫序列化的功能.可以把一个对象信息转化成二进制文件(或者xml文件)保存起来.下面举一个简单的例子,假如有类CArwen,实…

jQuery浏览器类型判断和分辨率判断

< DOCTYPE html PUBLIC -WCDTD XHTML TransitionalEN httpwwwworgTRxhtmlDTDxhtml-transitionaldtd>http://article.woshao.com/e6662006308d11e196d7000c2959fd2a&#xff0c;直接贴代码&#xff1a;<SCRIPT type"text/javascript">var bHeight$(window…

信息论与编码matlab实验报告,信息论与编码实验程序与结果图(matlab).doc

信息论与编码实验程序与结果图(matlab).doc 1信源熵实验程序&#xff1a;clc;closeall;clear;linwidd1fontt20p00;pd1;N20plinspace(p0,pd,N);I-log2(p);plot(p,I, k );title( I-log2(p)函数图 );xlabel( p );ylabel( I );clc;closeall;clear;linwidd1fontt20p00;pd1;N20plinsp…

OpenGL: 实现立体显示

立体显示原理&#xff1a;设没有立体显示的模型视图矩阵ModelView为Mv,投影矩阵为Mp&#xff0c;则、物体空间的任何一点为P&#xff0c;则变换到屏幕坐标P*MpMvP&#xff1b;注意前面已经说过opengl里面坐标列优先&#xff0c;所以矩阵都是右乘。 左眼和右眼的变换都是由中间的…

数学 之 hdu 4861

// [7/23/2014 Sjm] /* 对于此题&#xff0c;举出数据找规律&#xff0c;即可AC。。。 不过悲催的WA了好多次&#xff0c;后来发现竟把"YES"打印成"Yes"了。。。。 注释掉的代码是用来找规律的。。。 */ 1 #include <iostream>2 #include <cs…

linux下 如何调试php,linux下使用gdb对php源码调试

title: linux下使用gdb对php源码调试date: 2018-02-11 17:59:08tags:---linux下使用gdb进行php调试调试了一些php的漏洞&#xff0c;记录一下大概的过程安装编译phpsudo apt-get install -y autoconf libtool re2c libxml2-dev openssl libcurl4-openssl-dev libbz2-dev libjpe…

安装sqlserver2008,重新启动计算机不通过的解决办法

安装sqlserver2008&#xff0c;重新启动计算机不通过的解决办法 解决步骤&#xff1a;a 、重启机器&#xff0c;再进行安装&#xff0c;如果发现还有该错误&#xff0c;请按下面步骤b、在开始->运行中输入regeditc、到HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Control\…

php调用数据二行一组,PHPCMS v9指定行数从第2条或第N条开始调用数据的方法

在PHPCMSV9的模板中&#xff0c;如果想调用数据时&#xff0c;经常会遇到第一条新闻有缩略图文字&#xff0c;从第二条开始是文字列表&#xff1b;或者第一条标题字号字体和颜色特殊&#xff0c;第二条开始正常列表&#xff0c;这时候如果我们调用两次的话&#xff0c;会导致同…

线段树(单点更新(模板)) 之 hdu 1166

// [7/24/2014 Sjm] /* 第一道用线段树做的题&#xff0c;照着大神的代码风格写的&#xff0c;&#xff0c;就当作线段树单点更新的模板吧。。。。(当年用树状数组做的&#xff1a;代码见这里) */ 1 #include <iostream>2 #include <cstdlib>3 #include <cstdi…

深入浅出MFC文档/视图架构之文档模板

在"文档/视图"架构的MFC程序中&#xff0c;提供了文档模板管理者类CDocManager&#xff0c;由它管理应用程序所包含的文档模板。我们先看看这个类的声明&#xff1a; / // CDocTemplate manager object class CDocManager : public CObject {DECLARE_DYNAMIC(CDocMa…

深入浅出MFC文档/视图架构之文档

1、文档类CDocument在"文档/视图"架构的MFC程序中&#xff0c;文档是一个CDocument派生对象&#xff0c;它负责存储应用程序的数据&#xff0c;并把这些信息提供给应用程序的其余部分。CDocument类对文档的建立及归档提供支持并提供了应用程序用于控制其数据的接口&a…

centos 6 安装mysql,CentOS6.5安装MySQL教程(完整教程)

Step 1&#xff1a;检测系统是否安装MYSQL# yum list installed | grep mysql顺便提下如果yum有如下提示不能用的情况&#xff1a;yum在自动更新原因是yum在自动更新 只要关掉它就OK了解决方案&#xff1a;直接输入# rm -f /var/run/yum.pid或者&#xff1a;# /etc/init.d/y…

linux学习之一

忙啦几天&#xff0c;今天终于又有时间在这里打理本园子啦&#xff0c;今天写一下linux下磁盘如何自动挂载其实很简单&#xff0c;要让某些 partition 在开机的时候就自动挂载&#xff0c;写入 /etc/fstab 当中&#xff0c;或者是将指令完整的写到 /etc/rc.d/rc.local&#xff…

MFC 多文档源码分析1

添加模板在复写的CWinApp::InitInstance()函数中添加下面代码 CMultiDocTemplate* pDocTemplate; pDocTemplate new CMultiDocTemplate(IDR_SMARTTTYPE,RUNTIME_CLASS(CCosiWorksDoc),RUNTIME_CLASS(CChildFrame), // custom MDI child frameRUNTIME_CLASS(CCosiWorksView)); …

matlab求零空间,matlab求矩阵的零空间的一组整数基,该怎样操作?

匿名用户1级2015-09-18 回答第一部分&#xff1a;矩阵基本知识一、矩阵的创建直接输入法利用Matlab函数创建矩阵利用文件创建矩阵二、矩阵的拆分矩阵元素矩阵拆分特殊矩阵三、矩阵的运算算术运算关系运算逻辑运算四、矩阵分析对角阵三角阵矩阵的转置与旋转矩阵的翻转矩阵的逆与…

php通过条件来定义const,php用const出错是什么原因

大家都知道define是定义常量的,如果在类中定义常量呢&#xff1f;当然不能用define&#xff0c;而用const&#xff0c;如下例&#xff1a;<?php //在类外面通常这样定义常量define("PHP","phpernote.com");class MyClass{ //常量的值将始终保持不变。在…

UE4角色Location远距离时动画抖动问题(float精度不够)解决方案

正题&#xff1a;关于UE4引擎当角色Location超过9999.999后&#xff0c;角色动画更新抖动问题的解决思路。 前提&#xff1a; 1.UE4引擎中距离单位是厘米(cm)&#xff0c;也就说我们制作好1.8米的角色在UE4中为180个虚幻单位。这样做个人愚见是为了提高浮点值&#xff08;float…

android Handler的使用(一)

Handler的使用(一) Handler基本概念&#xff1a; Handler主要用于异步消息的处理&#xff1a;当发出一个消息之后&#xff0c;首先进入一个消息队列&#xff0c;发送消息的函数即刻返回&#xff0c;而另外一个部分逐个的在消息队列中将消息取出&#xff0c;然后对消息进行出来…

php和python的多线程,Python多线程以及线程锁简单理解(代码)

本篇文章给大家带来的内容是关于Python多线程以及线程锁简单理解(代码)&#xff0c;有一定的参考价值&#xff0c;有需要的朋友可以参考一下&#xff0c;希望对你有所帮助。多线程threading 模块创建线程创建自己的线程类线程通信线程同步互斥方法线程锁需要了解&#xff01;&a…