http://acm.nyist.net/JudgeOnline/problem.php?pid=42题目链接

  1. #include <cstdio>
  2. #include <cstring>
  3. #define CLR(arr) memset(arr,0,sizeof(arr))
  4. #define P 1001
  5. int G[P],fa[P];
  6. int find(int x){return x==fa[x]?x:x=find(fa[x]);}
  7. int main()
  8. {
  9.     int n,a,b,f,p,q;
  10.     scanf("%d",&n);
  11.     while(n--){
  12.         f=1;
  13.         scanf("%d%d",&p,&q);
  14.         for(int i=1;i<=p;i++)fa[i]=i;
  15.         while(q--){
  16.             scanf("%d%d",&a,&b);
  17.             G[a]++;//读取出入度
  18.             G[b]++;
  19.             fa[a]=find(b);
  20.         }
  21.         fa[a]=find(a);
  22.         for(int i=1;i<=p;i++)if((fa[i]=find(i))!=fa[a]){//判断各点是否在同一集合中
  23.             f=0;
  24.             break;
  25.         }
  26.         int sum=0;
  27.         if(f)//若已判断图为不连通,则不判断出入度
  28.         for(int i=1;i<=p;i++)if(G[i]%2){//判断出入度和是否为奇数
  29.             sum++;
  30.             if(sum>2){//出入度和为奇数,则不可能为欧拉道路
  31.                 f=0;
  32.                 break;
  33.             }
  34.         }
  35.         puts(f?"Yes\n":"No\n");
  36.         CLR(G);
  37.     }
  38.     return 0;
  39. }

一笔画,儿时经常玩的游戏,后来才知道,那叫欧拉道路,这题本质就是对欧拉道路的判断,根据已有定理,可形成欧拉道路的图中任意点的出入度和为奇数的个数不可以超过2个,因为有出必有入,这一点很容易编程实现,但上面的定理是基于图连通的情况下,因此我们还需要判断图的连通性,因为不想无脑dfs或bfs,于是上网查找更高效的图连通性判断算法,发现有所谓的传递闭包,想起白书里有,就翻了一天书,发作了两天鼻炎,最后发现这种方法是基于floyd算法实现的,时间复杂度是O(n3),还是不满意,就想用并查集实现,发现果然可行,但用了整整4ms,排行最高的只用了0ms,我想知道用 了什么方法,结果也是利用了并查集,而且方法更聪明(改到极致。。),这里也贴一下。(这算不算侵权。。。),并查集真是我见过最好用的数据结构,简单,代码少,应用性强。

  1. #include<stdio.h>
  2. #include<string.h>
  3. int father[1002];
  4. int Find(int x)
  5. {
  6.    if(father[x]==-1) return x;
  7.    return father[x]=Find(father[x]);
  8. }
  9. int main()
  10. {
  11.    int n,m,T,i,in[1002],a,b,sum,f;
  12.    scanf("%d",&T);
  13.    while(T--)
  14.    {
  15.       memset(in,0,sizeof(in));
  16.       memset(father,-1,sizeof(father));
  17.       scanf("%d%d",&n,&m);
  18.       for(i=0,sum=0;i<m;i++)
  19.       {
  20.          scanf("%d%d",&a,&b);
  21.          ++in[a]; ++in[b];
  22.          a=Find(a); b=Find(b);
  23.          if(a!=b) { father[a]=b; sum++; }
  24.       }
  25.       if(sum<n-1) { printf("No\n"); continue; }
  26.       for(i=1,f=0;i<=n;i++)
  27.          if(in[i]%2) { f++; if(f>2) break; }
  28.       if(f==0||f==2) printf("Yes\n");
  29.       else printf("No\n");
  30.    }
  31. }

Nyoj42 一笔画问题 (欧拉道路)的更多相关文章

  1. 6-14 Inspector s Dilemma uva12118(欧拉道路)

    题意:给出一个国家城市个数n   所需走过道路个数e   每条道路长t   该国家任意两个城市之间都存在唯一道路长t     要求 :找一条最短的路遍历所有所需走过的路 一开始以为是图的匹配  但是好 ...

  2. UVA 10129 Play on Words(欧拉道路)

    题意:给你n个字符串,问你是否可以出现一条链,保证链中每个字符串的第一个元素与上一个字符串的最后一个元素相同,注意可能重复出现同一个字符串 题解:以每一个字符串第一个元素指向最后一个元素形成一个有向图 ...

  3. Uva 10129 - Play on Words 单词接龙 欧拉道路应用

    跟Uva 10054很像,不过这题的单词是不能反向的,所以是有向图,判断欧拉道路. 关于欧拉道路(from Titanium大神): 判断有向图是否有欧拉路 1.判断有向图的基图(即有向图转化为无向图 ...

  4. UVa 10129 Play On Words【欧拉道路 并查集 】

    题意:给出n个单词,问这n个单词能否首尾接龙,即能否构成欧拉道路 按照紫书上的思路:用并查集来做,取每一个单词的第一个字母,和最后一个字母进行并查集的操作 但这道题目是欧拉道路(下面摘自http:// ...

  5. POJ 2513 Colored Sticks(欧拉道路+字典树+并查集)

    http://poj.org/problem?id=2513 题意: 给定一些木棒,木棒两端都涂上颜色,求是否能将木棒首尾相接,连成一条直线,要求不同木棒相接的一边必须是相同颜色的. 思路: 题目很明 ...

  6. UVA-10129 Play on Words (判断欧拉道路的存在性)

    题目大意:给出一系列单词,当某个单词的首字母和前一个单词的尾字母相同,则这两个单词能链接起来.给出一系列单词,问是否能够连起来. 题目分析:以单词的首尾字母为点,单词为边建立有向图,便是判断图中是否存 ...

  7. 【UVa】12118 Inspector's Dilemma(欧拉道路)

    题目 题目     分析 很巧秒的一道题目,对着绿书瞎yy一会. 联一下必须要走的几条边,然后会形成几个联通分量,统计里面度数为奇数的点,最后再减去2再除以2.这样不断相加的和加上e再乘以t就是答案, ...

  8. UVA 10441 - Catenyms(欧拉道路)

    UVA 10441 - Catenyms 题目链接 题意:给定一些单词,求拼接起来,字典序最小的,注意这里的字典序为一个个单词比过去,并非一个个字母 思路:欧拉回路.利用并查集判联通,然后欧拉道路判定 ...

  9. UVA10129———欧拉道路

    题目 输入n(n≤100000)个单词,是否可以把所有这些单词排成一个序列,使得每个单词的第一个字母和上一个单词的最后一个字母相同(例如 acm,malform,mouse).每个单词最多包含1000 ...

随机推荐

  1. hdu 4300 Clairewd’s message KMP应用

    Clairewd’s message 题意:先一个转换表S,表示第i个拉丁字母转换为s[i],即a -> s[1];(a为明文,s[i]为密文).之后给你一串长度为n<= 100000的前 ...

  2. 【BZOJ】1002: [FJOI2007]轮状病毒 递推+高精度

    1002: [FJOI2007]轮状病毒 Description 给定n(N<=100),编程计算有多少个不同的n轮状病毒. Input 第一行有1个正整数n. Output 将编程计算出的不同 ...

  3. MVC-EditorFor与TextBoxFor的区别

    EditorFor会根据后面提供的数据类型自动判断生成的控件类型(比如TextBox,CheckBox等): TextBoxFor生成的只是一个TextBox.

  4. BZOJ 1227 虔诚的墓主人

    Description 小W 是一片新造公墓的管理人.公墓可以看成一块N×M 的矩形,矩形的每个格点,要么种着一棵常青树,要么是一块还没有归属的墓地.当地的居民都是非常虔诚的基督徒,他们愿意提前为自己 ...

  5. A Full Hardware Guide to Deep Learning

    A Full Hardware Guide to Deep Learning Deep Learning is very computationally intensive, so you will ...

  6. BT5之网络配置

    输入ifconfig命令,可以查看当前IP地址设置情况.查看路由表的命令(用来检查默认网关是否设置正确):netstat -r 一.让BT5自动获取IP地址 自动获取IP地址,使用dhclient命令 ...

  7. PIL(Python Image Library)生成验证码

    # -*- coding: utf-8 -*-#导入三个模块import Image,ImageDraw,ImageFontimport randomimport math'''基本功能'''#图片宽 ...

  8. 『Asp.Net 组件』Asp.Net 服务器组件 内嵌CSS:将CSS封装到程序集中

    代码: <span style="font-family:Microsoft YaHei; font-size:12px">using System; using Sy ...

  9. USB Type-C接口完美无瑕?小心这五点

    今年下半年发布的新手机中,采用USB Type-C接口与传统micro USB接口的手机,所占比例大概是一半对一半.采用Type-C接口的手机大多数都是国产手机,而像三星.摩托罗拉以及索尼等老牌的手机 ...

  10. 释放SQL Server占用的内存

    由于Sql Server对于系统内存的管理策略是有多少占多少,除非系统内存不够用了(大约到剩余内存为4M左右),Sql Server才会释放一点点内存.所以很多时候,我们会发现运行Sql Server ...