脑残,竟然水不过!
题意很简单,就是判断无向图是否有单环。
方法:dfs给每一点染色,最后看是否还有点没有染色,如果有的话,就NO,否则就FHTAGN!。注意,当n!=m时就输出NO,因为有结论:如果存在单环,则点数=边数。
#include <vector>
#include <list>
#include <map>
#include <set>
#include <queue>
#include <string.h>
#include <deque>
#include <stack>
#include <bitset>
#include <algorithm>
#include <functional>
#include <numeric>
#include <utility>
#include <sstream>
#include <iostream>
#include <iomanip>
#include <cstdio>
#include <cmath>
#include <cstdlib>
#include <limits.h>
using namespace std;
int lowbit(int t){return t&(-t);}
int countbit(int t){return (t==0)?0:(1+countbit(t&(t-1)));}
int gcd(int a,int b){return (b==0)?a:gcd(b,a%b);}
int max(int a,int b){return a>b?a:b;}
int min(int a,int b){return a>b?b:a;}
#define LL long long
#define pi acos(-1)
#define N 1000010
#define INF INT_MAX
#define eps 1e-8
#define FRE freopen("a.txt","r",stdin)
vector<int> v[110];
int vis[110];
void dfs(int cur)
{
int i;
vis[cur]=1;
for(i=0;i<v[cur].size();i++)
{
int tmp=v[cur][i];
if(vis[tmp]==0)
{
dfs(tmp);
}
}
}
int main()
{
int n,m;
while(scanf("%d%d",&n,&m)!=EOF)
{
int i,j;
for(i=0;i<=n;i++)v[i].clear();
for(i=0;i<m;i++)
{
int a,b;
scanf("%d%d",&a,&b);
v[a].push_back(b);
v[b].push_back(a);
}
if(n!=m)//这里已经筛选出没环、多环(只有一条路径)
{
printf("NO\n");
}
else//对多条路径判断
{
for(i=0;i<=n;i++)vis[i]=0;
dfs(1);
for(i=1;i<=n;i++)
if(!vis[i])break;
if(i>n)printf("FHTAGN!\n");
else
printf("NO\n");
}
}
return 0;
}

1万+

被折叠的 条评论
为什么被折叠?



