hdu1116 欧拉回路
//Accepted 248 KB 125 ms
//欧拉回路
//以26个字母为定点,一个单词为从首字母到末尾字母的一条边
//下面就是有向图判断欧拉回路
//连通+节点入度和==出度和 或者 存在一对节点一个入度比出度大1,一个小1
#include <cstdio>
#include <cstring>
#include <iostream>
#include <queue>
using namespace std;
;
int a[imax_n][imax_n];
bool used[imax_n];
bool vis[imax_n];
int cnt_in[imax_n],cnt_out[imax_n];
int n;
];
queue<int >q;
void bfs(int s)
{
while (!q.empty()) q.pop();
//if (used[s]==0) return 0;
q.push(s);
vis[s]=;
while (!q.empty())
{
int x=q.front();
q.pop();
;i<imax_n;i++)
{
&& !vis[i] && a[x][i])
{
vis[i]=;
q.push(i);
}
}
}
}
bool judge()
{
int flag;
;i<=;i++)
{
memset(vis,,sizeof(vis));
bfs(i);
flag=;
;j<=;j++)
&& !vis[j]) flag=;
) ;
}
;
}
bool slove()
{
int p,ne;
p=ne=;
;i<=;i++)
{
int t=cnt_in[i]-cnt_out[i];
) continue;
)
{
p++;
) ;
continue;
}
)
{
ne++;
) ;
continue;
}
;
}
&& ne== || p== && ne==)) ;
;
}
int main()
{
int T;
scanf("%d",&T);
while (T--)
{
scanf("%d",&n);
int x,y;
memset(a,,sizeof(a));
memset(used,,sizeof(used));
memset(cnt_in,,sizeof(cnt_in));
memset(cnt_out,,sizeof(cnt_out));
;i<n;i++)
{
scanf("%s",s);
int l=strlen(s);
x=s[]-;
y=s[l-]-;
used[s[]-]=true;
used[s[l-]-]=true;
a[x][y]=;
cnt_out[x]++;
cnt_in[y]++;
}
&& slove()==)
printf("Ordering is possible.\n");
else
printf("The door cannot be opened.\n");
}
;
}
hdu1116 欧拉回路的更多相关文章
- hdu-1116(欧拉回路+并查集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1116 思路:将字符串的头元素和尾元素视为图的x,y节点,然后合并x,y. 如果这个图不连通,则门不能打 ...
- ACM/ICPC 之 混合图的欧拉回路判定-网络流(POJ1637)
//网络流判定混合图欧拉回路 //通过网络流使得各点的出入度相同则possible,否则impossible //残留网络的权值为可改变方向的次数,即n个双向边则有n次 //Time:157Ms Me ...
- [poj2337]求字典序最小欧拉回路
注意:找出一条欧拉回路,与判定这个图能不能一笔联通...是不同的概念 c++奇怪的编译规则...生不如死啊... string怎么用啊...cincout来救? 可以直接.length()我也是长见识 ...
- ACM: FZU 2112 Tickets - 欧拉回路 - 并查集
FZU 2112 Tickets Time Limit:3000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u P ...
- UVA 10054 the necklace 欧拉回路
有n个珠子,每颗珠子有左右两边两种颜色,颜色有1~50种,问你能不能把这些珠子按照相接的地方颜色相同串成一个环. 可以认为有50个点,用n条边它们相连,问你能不能找出包含所有边的欧拉回路 首先判断是否 ...
- POJ 1637 混合图的欧拉回路判定
题意:一张混合图,判断是否存在欧拉回路. 分析参考: 混合图(既有有向边又有无向边的图)中欧拉环.欧拉路径的判定需要借助网络流! (1)欧拉环的判定:一开始当然是判断原图的基图是否连通,若不连通则一定 ...
- codeforces 723E (欧拉回路)
Problem One-Way Reform 题目大意 给一张n个点,m条边的无向图,要求给每条边定一个方向,使得最多的点入度等于出度,要求输出方案. 解题分析 最多点的数量就是入度为偶数的点. 将入 ...
- UVa 12118 检查员的难题(dfs+欧拉回路)
https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&page=show_problem& ...
- UVA 10054 (欧拉回路) The Necklace
题目:这里 题意:有一种由彩色珠子连接而成的项链,每个珠子两半由不同颜色(由1到50的数字表示颜色)组成,相邻的两个珠子在接触的地方颜色相同,现在有一些零碎的珠子,确认它是否能 复原成完整的项链. 把 ...
随机推荐
- jsp 页面 jstl 日期的计算
1. <% page import ="java.util.Date"%> 2. <% Date date = new Date(); date = new Da ...
- 界面显示这个时间格式的js代码: 2016年1月19日 星期二 乙未(羊)年 腊月初十
today=new Date();function initArray(){ this.length=initArray.arguments.length for(var i=0;i<this. ...
- IOS开发—UIDatePicker 日期/时间选取器(滚轮)
UIDatePicker 是一个控制器类,封装了 UIPickerView,但是他是UIControl的子类,专门用于接受日期.时间和持续时长的输入.日期选取器的各列会按照指定的风格进行自动配置,这样 ...
- 日期操作类--GregorianCalendar类
GregorianCalendar--API JavaTM Platform Standard Ed. 6 GregorianCalendar类 Calendar类实现了公历日历,GregorianC ...
- WinForm应用程序之注册模块的设计与实现
Posted on 2012-11-13 10:21 星星之火116 阅读(3260) 评论(4) 编辑 收藏 我们在安装一些桌面应用程序的时候,往往在会有提示当前用户使用的是试用版,要进行注册.刚好 ...
- IE中JavaScript 的异常处理
错误类型 编程中我们会遇到四种错误:编译错误.逻辑错误.输入/验证错误.运行时错误,但是在JavaScript中我们只能最后两种错误. JavaScript 1.5定义了六种错误类型: EvalErr ...
- viewDidLoad && loadView
viewDidLoad 方法在controller加载了相关的views后被调用,而不论这些views存储在nib文件里还是在loadView函数中生成. loadView 方法在控制器的 view ...
- 修改Window的hosts文件提示“该文件被其他程序占用”解决方案
1.打开C:\Windows\System32\drivers\etc中的hosts 2.右键——>属性——>安全 3.在修改保存就可以了
- 读书笔记3 Socket
Socket被称为网络插座.用于两个网络应用程序之间的通信. 通信地址:URI 通过协议,地址,端口号可以确定网络上的一个程序.地址和端口号组合称之为端点. 通常会有发信人通信地址,收信人通信地址这两 ...
- Linux中Matlab保存多个数据到同一个文件当中
% load pyrim % NumTrain = 50; % load machine %NumTrain = 150; % load housing % NumTrain = 300; % loa ...