ACM/ICPC 之 欧拉回路两道(POJ1300-POJ1386)

时间:2021-12-04 23:19:28

两道有关欧拉回路的例题


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&sol;ICPC 之 平面几何-两直线关系&lpar;POJ 1269&rpar;

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

  2. ACM&sol;ICPC 之 Floyd范例两道&lpar;POJ2570-POJ2263&rpar;

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

  3. ACM&sol;ICPC 之 SPFA范例两道&lpar;POJ3268-POJ3259&rpar;

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

  4. ACM&sol;ICPC 之 两道dijkstra练习题&lpar;ZOJ1053&lpar;POJ1122&rpar;-ZOJ1053&rpar;

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

  5. 『ACM C&plus;&plus;』Virtual Judge &vert; 两道基础题 - The Architect Omar &amp&semi;&amp&semi; Malek and Summer Semester

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

  6. 2016 ACM&sol;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&commat;xmu&&num;183&semi;ACM&sol;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 &sol; ICPC 亚洲区域赛总结(长春站&amp&semi;北京站)

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

随机推荐

  1. &colon;nth-child&lpar;an&plus;b&rpar;

    语法: :nth-child(an+b)为什么选择它,因为我认为,这个选择器是最多学问的一个了.很可惜,据我所测,目前能较好地支持她的只有Opera9+和Safari3+. 描述: 伪类:nth-ch ...

  2. mysql重点--执行计划

    explain SQL: 在sql语句前面加explain实现"执行计划"的功能.功能是比较准确的显示将要执行这条sql语句的运行状况. select_simple 是查询类型:t ...

  3. ie 11 cookie 的值为空

    昨天碰到ie 11上运行的程序时  登录老是登录不上去 一直是登录界面 最后检查半天发现时因为 权限验证登录时 获取cookie里的用户信息时 一直为空 便在网上查询资料  发现是因为ie11 里貌似 ...

  4. php wampserver 80 端口无法开启的解决方法

    下载Microsoft Visual C++ 2005 Redistributable Package x86 和 x64(vc_redist.x86.exe/vc_redist.x64.exe) 安 ...

  5. css在各浏览器中的兼容问题

    CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理方法并 整理了一下.对于web2.0的过度,请尽量用xhtml ...

  6. cnUVA情况

    http://cn_uva.jd-app.com/ 欢迎访问

  7. machine learning in action &comma; part 1

    We should think in below four questions: the decription of machine learning key tasks in machine lea ...

  8. 1&period;4&period; 为现有的应用程序添加 Core Data 支持(Core Data 应用程序实践指南)

    项目创建时会有 “Use Core Data" ,但是,有时没有勾选这个选项,那么就要手动链接Core Data Framework. 选中 Grocery Dude Target Gene ...

  9. hdu3340 线段树&plus;多边形

    Rain in ACStar Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) T ...

  10. jzoj5879&period; 【NOIP2018提高组模拟9&period;22】电路图 B

    tj:一道好題 看區間操作可以想到線段樹 並聯操作公式:a1∗a2/(a1+a2)a1*a2/(a1+a2)a1∗a2/(a1+a2) 串聯操作公式:a1+a2a1+a2a1+a2 我們發現,一個區間 ...