zoukankan      html  css  js  c++  java
  • nyoj42一笔画问题(欧拉图)

    这题事实上说不上难度4。仅仅是一个简单的欧拉图推断,给一些点,首先推断连通性。假设不连通。就谈不上是欧拉图。

    假设是连通的,在推断度的数目,每一个顶点都是偶数个或者仅仅有两个奇数个。这样就能够构成欧拉图。

    一笔画问题

    时间限制: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"。
    例子输入
    4 3 
    1 2 
    1 3 
    1 4 
    4 5 
    1 2 
    2 3 
    1 3 
    1 4 
    3 4
    例子输出
    No 
    Yes
    #include<stdio.h>
    #include<string.h>
    #include<vector>
    using namespace std;
    vector <int > v[1005];
    int cnt;
    bool vis[1005];
    void dfs(int k)
    {
    	int i;
    	for(i=0;i<v[k].size();i++)
    	{
    		int t=v[k][i];
    		if(!vis[t])
    		{
    			vis[t]=true;
    			cnt++;
    			dfs(t);
    		}
    	}
    }
    int main()
    {
    	int N,n,m,a,b,i;
    	scanf("%d",&N);
    	while(N--)
    	{
    		memset(vis,false,sizeof(vis));
    		scanf("%d%d",&n,&m);
    		while(m--)
    		{
    			scanf("%d%d",&a,&b);
    			v[a].push_back(b);
    			v[b].push_back(a);
    		}
    		vis[b]=true;
    		cnt=1;
    		dfs(b);
    		int count=0;
    		if(cnt==n)
    		{			
    			for(i=1;i<=n;i++)
    			{
    				
    				if(v[i].size()&1) count++;
    				v[i].clear();
    			}
    		}
    		printf("%s
    ",(count==0 || count==2) && cnt==n?"Yes":"No");
    	}
    	return 0;
    }


  • 相关阅读:
    扩展的friend语法
    常量表达式
    字符串过滤,排序输出数字的问题
    decltype类型声明- 现代C++新特性总结
    auto类型-现代C++新特性
    指针相关总结2
    指针相关总结1
    发现XMind一个超级牛逼的功能
    空类指针为什么可以调用类的成员函数 以及 A(){}和A();
    SSAS父子层次结构的增强-UnaryOperatorColumn属性
  • 原文地址:https://www.cnblogs.com/cynchanpin/p/6755990.html
Copyright © 2011-2022 走看看