一笔画问题

时间限制:3000 ms  |  内存限制:65535 KB
难度:4
描述

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<iostream>
#include<vector>
#include<queue>
#include<algorithm>
using namespace std;
const int N=;
int visit[N];
int cnt;
vector< int >cc[N];
void dfs(int x)
{
visit[x]=;
int next=-;
for(int i=;i<cc[x].size();i++)
{
int tmp=cc[x][i];
if(!visit[tmp])
{
next=tmp;
break;
}
}
if(-!=next)
dfs(next);
}
int main()
{
int t,m,n,a,b,i;
cin>>t;
while(t--)
{int max=;
cin>>m>>n;
for(i=;i<=n;i++)
{
cin>>a>>b;
cc[a].push_back(b);
cc[b].push_back(a);
}
int start=;
for(i=;i<=m;++i)
{
if(cc[i].size()<cc[start].size())
start=i;
}
dfs(start);
bool flag=true;
for(i=;i<=m;i++)
if(!visit[i])
{
flag=false;
break;
}
if(!flag)
cout<<"No";
else
{
int j=;
for(i=;i<=m;i++)
if(cc[i].size()&)
j+=;
if(==j ||==j)
cout<<"Yes";
else cout<<"No";
}
for(i = ; i <=m; ++i)
{
visit[i]=;cc[i].clear();
}
cout<<endl;
}
return ;
}
 #include<stdio.h>
#include<string.h>
using namespace std;
int Edge[][],visited[],degree[];
void dfs(int cur,int v)
{
visited[cur]=;
int i;
for(i=;i<=v;i++)
if(Edge[cur][i]) //从邻接顶点往下寻找并计算出结点的度
{
degree[cur]++;
if(!visited[i]) //标记邻接顶点
dfs(i,v);
}
}
int main()
{
int test;
scanf("%d",&test);
while(test--)
{
int v,e;
memset(Edge,,sizeof(Edge));
memset(visited,,sizeof(visited));
memset(degree,,sizeof(degree));
scanf("%d%d",&v,&e);
int j,x,y,ok=;
for(j=;j<=e;++j)
{
scanf("%d%d",&x,&y);
Edge[x][y]=Edge[y][x]=;
}
dfs(,v);
for(j=;j<=v;++j) //循环判断图是否连通
{
if(visited[j]==)
{
ok=; //如果有点没有被连到
break;
}
}
if(!ok) printf("No\n");
else
{
j=;
for(int k=;k<=v;++k)
if(degree[k]%!=)
j+=;
if(j==||j==) //j=2时,则有两个点必为起点和终点,j=0,则任意点为起始点
printf("Yes\n");
else
printf("No\n");
}
}
}

ny42 一笔画问题的更多相关文章

  1. nyoj-一笔画问题-欧拉图+联通判定

    一笔画问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下 ...

  2. fcitx 候选词出现奇怪的笔画

    原来fcitx还有笔画输入的功能,输入h出现一个横,s出现竖,p是撇,n是捺,z是折. 虽然很有意思,但是不实用,而且还会出现在第一页候选词中,影响输入,可以通过配置文件禁用掉: $ vim ~/.c ...

  3. NYOJ 42 一笔画问题

    一笔画问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下 ...

  4. ACM题目————一笔画问题

    描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下来. 规定,所有的边都只能画一次,不能重复画. 输入 第一行只有一个正整数N(N< ...

  5. nyoj-----42一笔画问题

    一笔画问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:4   描述 zyc从小就比较喜欢玩一些小游戏,其中就包括画一笔画,他想请你帮他写一个程序,判断一个图是否能够用一笔画下 ...

  6. UVA 291 The House Of Santa Claus (DFS求一笔画)

    题意:从左下方1开始,一笔画出圣诞老人的屋子(不过话说,圣诞老人的屋子是这样的吗?这算是个屋子么),输出所有可以的路径. 思路:贴代码. #include <iostream> #incl ...

  7. nyist 42 一笔画 (欧拉回路 + 并查集)

    nyoj42 分析: 若图G中存在这样一条路径,使得它恰通过G中每条边一次,则称该路径为欧拉路径. 若该路径是一个圈,则称为欧拉(Euler)回路. 具有欧拉回路的图称为欧拉图(简称E图).具有欧拉路 ...

  8. Nyoj42 一笔画问题 (欧拉道路)

    http://acm.nyist.net/JudgeOnline/problem.php?pid=42题目链接 #include <cstdio> #include <cstring ...

  9. sql server 利用首字母拼音排序和笔画排序的语句

    --按笔画排序 select * from Student order by Sname COLLATE Chinese_PRC_Stroke_CS_AS_KS_WS --按字母拼音排序 select ...

随机推荐

  1. client高性能组件化框架React简单介绍、特点、环境搭建及经常使用语法

    [本文源址:http://blog.csdn.net/q1056843325/article/details/54729657 转载请加入该地址] 明天就是除夕了 预祝大家新春快乐 [ ]~( ̄▽ ̄) ...

  2. http 请求报文和响应报文

    1.请求报文 示例: 2.响应报文 示例:

  3. JavaScript toString、String和stringify方法区别

    <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title&g ...

  4. 记录规则 – 销售只能看到自己的客户,经理可以看到全部

    OpenERP中的权限管理有四个层次: 菜单级别: 即,不属于指定菜单所包含组的用户看不到该菜单.不安全,只是隐藏菜单,若用户知道菜单ID,仍然可以通过指定URL访问 对象级别: 即,对某个对象是否有 ...

  5. Openerp 7 view画面编辑/创建/删除/复制功能控制

    OpenERP 7.0中,Tree或Form画面上可以添加属性create edit delete,用于控制Create.Delete.Edit.Duplicate功能是否显现.如下例:<for ...

  6. eclipse 图片预览插件

      eclipse 图片预览插件 CreateTime--2018年4月22日22:59:55 Author:Marydon 下载地址:eclipse 图片预览插件 将插件文件夹直接拷贝到eclips ...

  7. 分离Command

    要点: 1.请求类必须继承CommandBase 2.请求类类名为请求对象中的Key值,大小写可以不区分 3.类必须用public修饰,否则无法识别该请求,提示为无效请求 4.不能再调用NewRequ ...

  8. putty简单使用

    一.Putty简介 Putty是一款轻便的远程登录工具,用它可以非常方便的登录到Linux服务器上进行各种操作(命令行方式).Putty完全免费,而且无需安装(双击即可运行),支持多种连接类型(Tel ...

  9. java线上应用问题排查方法和工具

    linux性能监测点 CPU, Memory, IO, Network Linux性能监测工具-cpu 基本概念: 上下文切换(Context Switches): 如果可运行的线程数大于CPU的数量 ...

  10. 基于Arch的live系统

    今天在linuxsir的archlinux分区闲逛,看到了carbonjiao的帖子 http://bbs.linuxeye.cn/thread-652-1-1.html 同时还关注他的帖子:1.Ar ...