ACM/ICPC 之 欧拉回路两道(POJ1300-POJ1386)
两道有关欧拉回路的例题
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)的更多相关文章
- ACM/ICPC 之 平面几何-两直线关系(POJ 1269)
题意:给定四点的坐标(x,y),分别确定两直线,求出其交点,若重合or平行则输出相应信息 用四个点的坐标算出直线通式(ax+by+c=0)中的a,b,c,然后利用a,b,c计算出交点坐标(其他公式不够 ...
- ACM/ICPC 之 Floyd范例两道(POJ2570-POJ2263)
两道以Floyd算法为解法的范例,第二题如果数据量较大,须采用其他解法 POJ2570-Fiber Network //经典的传递闭包问题,由于只有26个公司可以采用二进制存储 //Time:141M ...
- ACM/ICPC 之 SPFA范例两道(POJ3268-POJ3259)
两道以SPFA算法求解的最短路问题,比较水,第二题需要掌握如何判断负权值回路. POJ3268-Silver Cow Party //计算正逆最短路径之和的最大值 //Time:32Ms Memory ...
- ACM/ICPC 之 两道dijkstra练习题(ZOJ1053(POJ1122)-ZOJ1053)
两道较为典型的单源最短路径问题,采用dijkstra解法 本来是四道练习题,后来发现后面两道用dijkstra来解的话总觉得有点冗余了,因此暂且分成三篇博客(本篇以及后两篇). ZOJ1053(POJ ...
- 『ACM C++』Virtual Judge | 两道基础题 - The Architect Omar && Malek and Summer Semester
这几天一直在宿舍跑PY模型,学校的ACM寒假集训我也没去成,来学校的时候已经18号了,突然加进去也就上一天然后排位赛了,没学什么就去打怕是要被虐成渣,今天开学前一天,看到最后有一场大的排位赛,就上去试 ...
- 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 ...
- 【转】lonekight@xmu·ACM/ICPC 回忆录
转自:http://hi.baidu.com/ordeder/item/2a342a7fe7cb9e336dc37c89 2009年09月06日 星期日 21:55 初识ACM最早听说ACM/ICPC ...
- ACM - ICPC World Finals 2013 C Surely You Congest
原题下载:http://icpc.baylor.edu/download/worldfinals/problems/icpc2013.pdf 题目翻译: 试题来源 ACM/ICPC World Fin ...
- 2015 ACM / ICPC 亚洲区域赛总结(长春站&北京站)
队名:Unlimited Code Works(无尽编码) 队员:Wu.Wang.Zhou 先说一下队伍:Wu是大三学长:Wang高中noip省一:我最渣,去年来大学开始学的a+b,参加今年区域赛之 ...
随机推荐
- struts2上传文件添加进度条
给文件上传添加进度条,整了两天终于成功了. 想要添加一个上传的进度条,通过分析,应该是需要不断的去访问服务器,询问上传文件的大小.通过已上传文件的大小, 和上传文件的总长度来评估上传的进度. 实现监听 ...
- 如何提高MySQL Limit查询的性能
MYSQL的优化是非常重要的.其他最常用也最需要优化的就是limit.mysql的limit给分页带来了极大的方便,但数据量一大的时候,limit的性能就急剧下降. 同样是取10条数据 select ...
- Node.SelectNodes
http://www.crifan.com/csharp_under_some_node_search_specific_child_node/ https://msdn.microsoft.com/ ...
- 密码学初级教程(六)数字签名 Digital Signature
密码学家工具箱中的6个重要的工具: 对称密码 公钥密码 单向散列函数 消息认证码 数字签名 伪随机数生成器 提问: 有了消息认证码为什么还要有数字签名? 因为消息认证码无法防止否认.消息认证码可以识别 ...
- 2015年11月26日 Java基础系列(一)之String与StringBuffer与StringBuilder的区别
序,StringBuffer是线程安全的,StringBuilder是线程不安全的,但是StringBuilder操作速度快,因此在使用时要根据场景合理选择. StringBuffer和StringB ...
- sql移除换行回车符号 \r\n
--移除回车符 update master_location SET street_number = REPLACE(street_number, CHAR(13), '') --移除换行符 upda ...
- 网站SEO优化之添加Sitemap文件。
Sitemap.xml 故名思意就是站点地图文件,可以指引Google spider 收录相应网页.正确地使用Google Sitemap,可以确保让Google spider 不遗漏网站内的任何页面 ...
- linux下系统对于sigsegv错误时的处理
一般来讲,对非法地址的访问会导致应用程序收到由系统发送的sigsegv信号,默认情况下,函数对于这个信号的处理是退出. 但是为了方便调试,我们可以自己设置处理函数,使用signal函数. 这里比较重要 ...
- JQuery-EasyUI DataGrid CRUD
ASP.NET使用EasyUI-DataGrid + ashx + JQuery Ajax:实现数据的增删查改,查询和分页! 数据表: 学生表:学生编号.姓名.性别.班级编号.年龄 班级表:班级编号. ...
- <s:url>指向的Action只执行一次,清除浏览器缓存文件后又可执行一次。
Action中的方法仅为静态变量赋值,而其他访问数据库的Action可以被重复执行. 起初判断可能是静态变量的内存机制导致不能重复执行. 然后发现清楚浏览器缓存文件后又可以执行一次了,看来原因在Jsp ...