判断一个图是否存在环

Description

给出一个有向图,判断图中是否存在回路。

Input

1 行:输入图的顶点个数 N  N  2,500 )和 C (图的边数,  C   6,200 );
2 C+1 行中,第 i+1 行输入两个整数,分别表示第 i 条边的起点和终点的编号。

Output

如果图中存在回路,输出“ YES ”,否则,输出“ NO ”。

Sample Input

7 8
1 2
1 3
2 4
2 6
3 4
4 5
5 2
5 7

Sample

YES


大致的思路是深搜,将深搜的点加一个特殊标记,如果从当前的点往下搜的时候,发现了这个特殊标记,立刻判定有环。

代码如下

[cpp]  view plain copy
  1. #include<cstdio>  
  2. #include<cstring>  
  3. int n,c,a[2600][2600],vis[2600],swi;  
  4. int dfs(int v){      
  5.     vis[v] = -1;      
  6.     for(int i = 1; i <= n; i++)      
  7.     {          
  8.         if(a[v][i] != 0 && !vis[i])  {            
  9.             dfs(i);          
  10.             vis[i]=1;  
  11.         }  
  12.         if(a[v][i] != 0 && vis[i] == -1){       
  13.             printf("YES\n");  
  14.             swi=true;  
  15.             return true;      
  16.         }  
  17.     }      
  18.     return false;  
  19. }  
  20. int main(){  
  21.     memset(a,0,sizeof(a));  
  22.     memset(vis,0,sizeof(vis));  
  23.     swi=false;  
  24.     scanf("%d %d",&n,&c);  
  25.     int r1,r2;  
  26.     for(int i=0;i<c;++i){  
  27.         scanf("%d %d",&r1,&r2);  
  28.         a[r1][r2]=1;  
  29.     }  
  30.     dfs(1);  
  31.     if(!swi) printf("NO\n");  
  32. }  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值