两道有关欧拉回路的例题


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. mysql max_allowed_packet查询和修改

    http://www.2cto.com/database/201303/195830.html mysql根据配置文件会限制server接受的数据包大小. 有时候大的插入和更新会被max_allowe ...

  2. System.nanoTime与System.currentTimeMillis的区别

    平时产生随机数时我们经常拿时间做种子,比如用 System.currentTimeMillis的结果,但是在执行一些循环中使用了System.currentTimeMillis,那么每次的结 果将会差 ...

  3. echo '.SUFFIXES: .cpp' >> ${OUTPUT_FILE}

    当前makefile或shell内支持文件后缀的类型列表,意思是文件支持.cpp结尾的类型,并且将他,输出到OUTPUT_FILE函数. 见网上有人说: “makefile中 .SUFFIXES: . ...

  4. dreamwaver的动态相关文件 工具栏搜索

    dreamwaver是很好的编辑工具, 用过很多ide, 对php,js, css代码来说, dw确实是很好很方便的一个工具 php本身设置了很多的 预定义常量, 函数, 可以用来获取当前运行php的 ...

  5. python中raw_input() 与 input()

    参考网址:http://www.cnblogs.com/way_testlife/archive/2011/03/29/1999283.html 在python中如何接收一个输入的字符串. 举个例子: ...

  6. linux 打造man中文帮助手册

    博客转自:http://my.oschina.net/hbzhangmao/blog/354533 学IT的同学都知道, Linux是一个好东西, 但初学者往往会因为太多的命令觉得头疼, 更头疼的是所 ...

  7. [整理]VS2013常用插件

    VS2013常用插件 (工欲善其事,必先利其器.VS2013全攻略(技巧,快捷键,插件)[http://developer.51cto.com/art/201404/437282_all.htm] 代 ...

  8. 浅谈javascript函数节流

    浅谈javascript函数节流 什么是函数节流? 函数节流简单的来说就是不想让该函数在很短的时间内连续被调用,比如我们最常见的是窗口缩放的时候,经常会执行一些其他的操作函数,比如发一个ajax请求等 ...

  9. 计划安装SQL Server2012需求详细

    1.查看 SQL Server2012 安装的安装要求.系统配置检查和安全注意事项. 1.1 硬件要求 [参考资料http://msdn.microsoft.com/zh-cn/library/ms1 ...

  10. ajax浅析---UpdatePanel

    使用UpdatePanel控件 UpdatePanel可以用来创建丰富的局部更新Web应用程序,它是ASP.NET 2.0 AJAX Extensions中很重要的一个控件,其强大之处在于不用编写任何 ...