两道有关欧拉回路的例题


POJ1300-Door Man

//判定是否存在从某点到0点的欧拉回路
//Time:0Ms Memory:116K
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std; #define MAX 25
int st, n;
int door[MAX]; int main()
{
char s[120];
while (scanf("%s", s), strcmp(s, "ENDOFINPUT"))
{
memset(door, 0, sizeof(door));
int doors = 0;
scanf("%d%d", &st, &n);
gets_s(s, 120);
for (int i = 0; i < n; i++)
{
gets_s(s, 120);
int num, k = 0;
while (sscanf(s + k, "%d", &num) == 1)
{
doors++;
door[num]++;
door[i]++;
while (s[k] == ' ') k++;
while (s[k] && s[k] != ' ') k++;
}
}
gets_s(s, 120);
int odd = 0;
for (int i = 0; i < n; i++)
odd += door[i] % 2 == 1;
if (odd == 0 && st == 0)
printf("YES %d\n", doors); //无奇度节点
else if (odd == 2 && st && door[st] % 2 && door[0] % 2)
printf("YES %d\n", doors); //两个奇度节点
else printf("NO\n");
}
return 0;
}

POJ1386-Plays on Words

//判断能否使给定的词组前后接龙
//Time:344Ms Memory:120K
#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std; #define MAX 28
#define MAXS 1005
#define MAXN 100005 int n;
char s[MAXS];
int in[MAX], out[MAX];
int fa[MAX]; int find(int x)
{
return fa[x] < 0 ? x : find(fa[x]);
} int Union(int r1, int r2)
{
r1 = find(r1); r2 = find(r2);
if (r1 == r2) return r1;
int tmp = fa[r1] + fa[r2];
if (fa[r1] > fa[r2])
{
fa[r1] = r2;
fa[r2] = tmp;
return r2;
}
else {
fa[r2] = r1;
fa[r1] = tmp;
return r1;
}
} int main()
{
//freopen("words.in", "r", stdin);
int T;
scanf("%d", &T);
while (T--) {
memset(in, 0, sizeof(in));
memset(out, 0, sizeof(out));
memset(fa, -1, sizeof(fa)); int pa;
scanf("%d", &n);
while (n--) {
scanf("%s", s);
int i = s[strlen(s) - 1] - 'a';
int o = s[0] - 'a';
out[o]++; in[i]++;
pa = Union(i, o);
} int odd = 0;
bool connect = true;
bool A = false, B = false;
for (int i = 0; i < 26; i++)
{
if (!in[i] && !out[i]) continue;
if (pa != find(i)) {
connect = false; break;
}
if (in[i] - out[i] != 0)
{
odd++;
if (in[i] - out[i] == 1) A = true;
if (in[i] - out[i] == -1) B = true;
}
}
if (connect && ((odd == 2 && A && B) || odd == 0))
printf("Ordering is possible.\n");
else printf("The door cannot be opened.\n");
} return 0;
}

ACM/ICPC 之 欧拉回路两道(POJ1300-POJ1386)的更多相关文章

  1. ACM/ICPC 之 平面几何-两直线关系(POJ 1269)

    题意:给定四点的坐标(x,y),分别确定两直线,求出其交点,若重合or平行则输出相应信息 用四个点的坐标算出直线通式(ax+by+c=0)中的a,b,c,然后利用a,b,c计算出交点坐标(其他公式不够 ...

  2. ACM/ICPC 之 Floyd范例两道(POJ2570-POJ2263)

    两道以Floyd算法为解法的范例,第二题如果数据量较大,须采用其他解法 POJ2570-Fiber Network //经典的传递闭包问题,由于只有26个公司可以采用二进制存储 //Time:141M ...

  3. ACM/ICPC 之 SPFA范例两道(POJ3268-POJ3259)

    两道以SPFA算法求解的最短路问题,比较水,第二题需要掌握如何判断负权值回路. POJ3268-Silver Cow Party //计算正逆最短路径之和的最大值 //Time:32Ms Memory ...

  4. ACM/ICPC 之 两道dijkstra练习题(ZOJ1053(POJ1122)-ZOJ1053)

    两道较为典型的单源最短路径问题,采用dijkstra解法 本来是四道练习题,后来发现后面两道用dijkstra来解的话总觉得有点冗余了,因此暂且分成三篇博客(本篇以及后两篇). ZOJ1053(POJ ...

  5. 『ACM C++』Virtual Judge | 两道基础题 - The Architect Omar && Malek and Summer Semester

    这几天一直在宿舍跑PY模型,学校的ACM寒假集训我也没去成,来学校的时候已经18号了,突然加进去也就上一天然后排位赛了,没学什么就去打怕是要被虐成渣,今天开学前一天,看到最后有一场大的排位赛,就上去试 ...

  6. 2016 ACM/ICPC Asia Regional Qingdao Online(2016ACM青岛网络赛部分题解)

    2016 ACM/ICPC Asia Regional Qingdao Online(部分题解) 5878---I Count Two Three http://acm.hdu.edu.cn/show ...

  7. 【转】lonekight@xmu·ACM/ICPC 回忆录

    转自:http://hi.baidu.com/ordeder/item/2a342a7fe7cb9e336dc37c89 2009年09月06日 星期日 21:55 初识ACM最早听说ACM/ICPC ...

  8. ACM - ICPC World Finals 2013 C Surely You Congest

    原题下载:http://icpc.baylor.edu/download/worldfinals/problems/icpc2013.pdf 题目翻译: 试题来源 ACM/ICPC World Fin ...

  9. 2015 ACM / ICPC 亚洲区域赛总结(长春站&北京站)

    队名:Unlimited Code Works(无尽编码)  队员:Wu.Wang.Zhou 先说一下队伍:Wu是大三学长:Wang高中noip省一:我最渣,去年来大学开始学的a+b,参加今年区域赛之 ...

随机推荐

  1. Kafka入门经典教程

      本帖最后由 desehawk 于 2015-5-3 00:45 编辑问题导读 1.Kafka独特设计在什么地方?2.Kafka如何搭建及创建topic.发送消息.消费消息?3.如何书写Kafka程 ...

  2. mongodb 与 c++ 的配合使用

    最近在尝试使用 mongodb 作为服务端持久化方案,服务端程序是使用 c++ 写的,折腾了不少时间,记录一下吧. 1.下载 boost 1.56.0 http://www.boost.org/use ...

  3. [译]git pull

    git pull把git fetch和git merge压缩成了一条命令. 用法 git pull <remote> 作用和git fetch <remote> &&a ...

  4. mysql sql语句执行时间查询

    第一种:show profiles 之类的语句来查看 1.查一下profile是不是打开了,默认是不打开的. mysql> show profiles; Empty set (0.02 sec) ...

  5. HTML Table导出为Excel的方法

    HTML Table导出为Excel的方法: 直接上源码 <html> <head> <meta http-equiv="Content-Type" ...

  6. hdu.1111.Secret Code(dfs + 秦九韶算法)

    Secret Code Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others) Tota ...

  7. 【C语言入门教程】3.2 数据的输入 与 输出

    在程序的运行过程中,通常需要用户输入一些数据,而程序运算所得到的计算结果等又需要输出给用户,由此实现人与计算机之间的交互.所以在程序设计中,输入输出语句是一类必不可少的重要语句.在 C 语言中,没有专 ...

  8. Hibernate框架之入门案例

    今天终于开始学习了三大框架的其中一个框架,Hibernate框架,在这里不去讲Hibernate框架的一些基础概念了,直接切入代码,带大家了解一下Hibernate能干什么, Hibernate的人们 ...

  9. php访问全局变量

    函数之外声明的变量拥有 Global 作用域,只能在函数以外进行访问. 函数内部声明的变量拥有 LOCAL 作用域,只能在函数内部进行访问. PHP 同时在名为 $GLOBALS[index] 的数组 ...

  10. 淘宝(阿里百川)手机客户端开发日记第十二篇 mysql的认识

    我这里用的是wamp,大家可以到网上去下载对应的包,自行安装,对于程序员来讲,安装软件大部分都应该不是问题的,所以我不去将具体安装的方法. wamp安装好后,在我们屏幕的右下角, 这样的图标,我们右键 ...