Nyoj 一笔画问题(图论)
描述
zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下来。
规定,所有的边都只能画一次,不能重复画。
- 输入
 - 第一行只有一个正整数N(N<=10)表示测试数据的组数。
每组测试数据的第一行有两个正整数P,Q(P<=1000,Q<=2000),分别表示这个画中有多少个顶点和多少条连线。(点的编号从1到P)
随后的Q行,每行有两个正整数A,B(0<A,B<P),表示编号为A和B的两点之间有连线。 - 输出
 - 如果存在符合条件的连线,则输出"Yes",
如果不存在符合条件的连线,输出"No"。 - 样例输入
 - 
2
4 3
1 2
1 3
1 4
4 5
1 2
2 3
1 3
1 4
3 4 - 样例输出
 - 
No
Yes 每个点对应的度 再用到欧拉回路 
代码:
#include <vector>
#include <map>
#include <set>
#include <algorithm>
#include <iostream>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <string>
#include <cstring>
#include <queue>
using namespace std; #define N 1010
int g[N][N];
bool vis[N]; int bfs(int n)
{
queue<int> q;
int que,du,odd,i;
memset(vis,,sizeof(vis));
q.push();
vis[] = ;
que = ; //队列中点的个数
odd = ; //度为奇数的点的个数
while(!q.empty()){
int top=q.front();
q.pop(); que++;
du=;
for(int i=; i<=n; i++){
if(g[top][i]){
if(!vis[i]){
q.push(i);
vis[i]=;
}
du++;
}
}
if(du&) odd++;
}
if((odd== || odd==)&& que==n) printf("Yes\n");
else printf("No\n");
} int main()
{
int n;
int P,Q,p,q;
scanf("%d",&n);
while(n--){
memset(g,,sizeof(g));
scanf("%d %d",&P,&Q);
while(Q--){
scanf("%d %d",&p,&q);
g[p][q]=g[q][p]=;
}
bfs(P);
}
}
Nyoj 一笔画问题(图论)的更多相关文章
- NYOJ 一笔画
		
# include<iostream> # include<string> # include<string.h> # include<queue> # ...
 - nyoj 一笔画问题
		
一笔画问题 描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下来. 规定,所有的边都只能画一次,不能重复画. 输入 第一行只有一个正整 ...
 - NYOJ 一笔画问题 欧拉路
		
一笔画问题 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下 ...
 - nyoj  42-一笔画问题 (欧拉图 && 并查集)
		
42-一笔画问题 内存限制:64MB 时间限制:3000ms Special Judge: No accepted:10 submit:25 题目描述: zyc从小就比较喜欢玩一些小游戏,其中就包括画 ...
 - Nyoj  城市平乱(图论)
		
描述 南将军统领着N个部队,这N个部队分别驻扎在N个不同的城市. 他在用这N个部队维护着M个城市的治安,这M个城市分别编号从1到M. 现在,小工军师告诉南将军,第K号城市发生了暴乱,南将军从各个部队都 ...
 - Nyoj  吝啬的国度(图论&&双DFS)
		
描述在一个吝啬的国度里有N个城市,这N个城市间只有N-1条路把这个N个城市连接起来.现在,Tom在第S号城市,他有张该国地图,他想知道如果自己要去参观第T号城市,必须经过的前一个城市是几号城市(假设你 ...
 - NYOJ 42 一笔画问题
		
一笔画问题 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下 ...
 - NYOJ     42   一笔画问题    (并查集+欧拉回路 )
		
题目链接 描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下来. 规定,所有的边都只能画一次,不能重复画. 输入 第一行只有一个正整数 ...
 - nyoj 42 一笔画  欧拉通路
		
http://acm.nyist.net/JudgeOnline/problem.php?pid=42 一笔画问题 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 zyc ...
 
随机推荐
- projecteuler---->problem=14----Longest Collatz sequence
			
title: The following iterative sequence is defined for the set of positive integers: n n/2 (n is eve ...
 - char与unsigned char 差别
			
char 与 unsigned char的本质差别 http://bbs.csdn.net/topics/270080484 同一个内存内容:10010000 你用char* 解释是-1 ...
 - [WebGL入门]二十四,补色着色
			
注:文章译自http://wgld.org/,原作者杉本雅広(doxas),文章中假设有我的额外说明,我会加上[lufy:],另外,鄙人webgl研究还不够深入,一些专业词语,假设翻译有误,欢迎大家指 ...
 - PC2日记——坑爹的第一天2014/08/28
			
我不想安慰自己说今天是因为第一次将pc2用于实际的比赛经验不足而导致的今天出现种种问题,我想说的是自从我開始干后台我所做的每一件事都是第一次,所以这绝对不是让自己免去责怪的理由:我想说的是假设我今天是 ...
 - ebay的api开发技术说明,有点乱
			
使用eBay API的基本步骤引入 开始eBay API,例如,以下基本步骤需要: 1. 注册开发者账号: https://developer.ebay.com/join/Default.asp ...
 - Oracle性能优化顺序表名称来选择最有效的学习笔记
			
选择最有效的顺序表名(只有有效的基于规则的优化) ORACLE分析器按照订单处理从右到左FROM在FROM子句中的表名,故FROM写在最后的表(基础表 driving table)将被最先处理. 在 ...
 - quick-cocos2d-x endToLua 退出会卡住
			
问题: 马上赚钱,退出会出现卡住,然后清理,死界面的情况,百思不得其解,昨天在做push的时候,突然发现.在android里面弹出一个退出对话框,点击确定退出,这时候调用endtolua时,有时也会切 ...
 - 怎样解决No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=x86_64, VALID_ARCHS=i386).
			
怎样解决No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=x86_64, VALID_ARCHS=i386). 错误 ...
 - Linux鸟哥的私房菜(3)— 总体规划和磁盘分区 读书笔记
			
1.每个硬件设备Linux中的文件名称 在Linux系统中.每一个设备都被当成一个文件来对待.而且差点儿全部的硬件设备文件都在/dev文件夹下 常见设备与其对于文件名称 2.磁盘连接的方式与设备文件名 ...
 - poj2386 Lake Counting(简单DFS)
			
转载请注明出处:viewmode=contents">http://blog.csdn.net/u012860063?viewmode=contents 题目链接:http://poj ...