Legal or Not HDU
Legal or Not
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 3060 Accepted Submission(s): 1386
We all know a master can have many prentices and a prentice may have a lot of masters too, it's legal. Nevertheless,some cows are not so honest, they hold illegal relationship. Take HH and 3xian for instant, HH is 3xian's master and, at the same time, 3xian is HH's master,which is quite illegal! To avoid this,please help us to judge whether their relationship is legal or not.
Please note that the "master and prentice" relation is transitive. It means that if A is B's master ans B is C's master, then A is C's master.
TO MAKE IT SIMPLE, we give every one a number (0, 1, 2,..., N-1). We use their numbers instead of their names.
If it is legal, output "YES", otherwise "NO".
0 1
1 2
2 2
0 1
1 0
0 0
NO
简单版
#include <stdio.h>
#include <string.h> const int MAX = 100 + 10;
int n,m,G[MAX][MAX],c[MAX];
bool DFS(int u)
{
c[u] = -1;
for(int v = 0;v < n;v++)if(G[u][v])
{
if(c[v]<0) return false;
if(!c[v]&&!DFS(v)) return false;
}
c[u] = 1;
return true;
}
bool TopSort()
{
memset(c,0,sizeof(c));
for(int v = 0;v < n;v++)if(!c[v])
if(!DFS(v)) return false;
return true;
}
int main()
{
while(scanf("%d%d",&n,&m),n)
{
int x,y;
memset(G,0,sizeof(G));
for(int i = 0;i < m;i++)
{
scanf("%d%d",&x,&y);
G[x][y] = 1;
}
if(TopSort())
printf("YES\n");
else
printf("NO\n");
}
return 0;
}
复杂版(邻接表)
#include <iostream>
#include <cstdlib>
#include <queue>
using namespace std; const int MaxVertexNum = 100;
typedef int VertexType;
typedef struct node
{
int adjvex;
node* next;
}EdgeNode;
typedef struct
{
VertexType vertex;
EdgeNode* firstedge;
int count;
}VertexNode;
typedef VertexNode AdjList[MaxVertexNum];
typedef struct
{
AdjList adjlist;
int n,e;
}ALGraph;
bool CreatALGraph(ALGraph *G)
{
int i,j,k;
EdgeNode* s;
cin>>G->n>>G->e;
if(G->n == 0)
return false;
for(i = 0;i < G->n;i++)
{
G->adjlist[i].vertex = i;
G->adjlist[i].firstedge = NULL;
}
for(k = 0;k < G->e;k++)
{
cin>>i>>j;
s = (EdgeNode *)malloc(sizeof(EdgeNode));
s->adjvex = j;
s->next = G->adjlist[i].firstedge;
G->adjlist[i].firstedge = s;
}
return true;
} void TopSort(ALGraph *G)
{
EdgeNode *p;
queue<int> Q;
int i,j,cnt = 0;
for(i = 0;i < G->n;i++)
G->adjlist[i].count = 0;
for(i = 0;i < G->n;i++)
{
p = G->adjlist[i].firstedge;
while(p != NULL)
{
G->adjlist[p->adjvex].count++;
p = p->next;
}
}
for(i = 0;i < G->n;i++)
if(G->adjlist[i].count == 0)
Q.push(i);
while(!Q.empty())
{
i = Q.front();
Q.pop();
cnt++;
p = G->adjlist[i].firstedge;
while(p != NULL)
{
j = p->adjvex;
G->adjlist[j].count--;
if(G->adjlist[j].count == 0)
Q.push(j);
p = p->next;
}
}
if(cnt != G->n)
cout<<"NO"<<endl;
else
cout<<"YES"<<endl;
} int main()
{
ALGraph G;
while(CreatALGraph(&G))
TopSort(&G);
return 0;
}
Legal or Not HDU的更多相关文章
- Legal or Not HDU - 3342 (拓扑排序)
注意点: 输入数据中可能有重复,需要进行处理! #include <stdio.h> #include <iostream> #include <cstring> ...
- HDU 3342 Legal or Not(判断是否存在环)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3342 Legal or Not Time Limit: 2000/1000 MS (Java/Othe ...
- hdu 3342 Legal or Not
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=3342 Legal or Not Description ACM-DIY is a large QQ g ...
- HDU.3342 Legal or Not (拓扑排序 TopSort)
HDU.3342 Legal or Not (拓扑排序 TopSort) 题意分析 裸的拓扑排序 根据是否成环来判断是否合法 详解请移步 算法学习 拓扑排序(TopSort) 代码总览 #includ ...
- HDU——T 3342 Legal or Not
http://acm.hdu.edu.cn/showproblem.php?pid=3342 Time Limit: 2000/1000 MS (Java/Others) Memory Limi ...
- hdu 3342 Legal or Not(拓扑排序)
Legal or Not Time Limit : 2000/1000ms (Java/Other) Memory Limit : 32768/32768K (Java/Other) Total ...
- HDU 3342 Legal or Not(有向图判环 拓扑排序)
Legal or Not Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Tota ...
- HDU 3342:Legal or Not(拓扑排序)
Legal or Not Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) Tot ...
- HDU 3342 Legal or Not(拓扑排序判断成环)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3342 题目大意:n个点,m条有向边,让你判断是否有环. 解题思路:裸题,用dfs版的拓扑排序直接套用即 ...
随机推荐
- hdu 5532 (LIS) Almost Sorted Array
http://acm.hdu.edu.cn/showproblem.php?pid=5532 题意大致是一组数中去掉一个数后问剩下的数是否构成非严格单调序列 正反各跑一遍最长非严格连续子序列,存在长度 ...
- 关于ip包长度
http://blog.csdn.net/naturebe/article/details/6712153 这篇文章总结的不错,转自:http://hi.baidu.com/to_wait/blog/ ...
- LaTeX数学公式大全
原写于我的洛谷博客(传送门),现搬到这个博客上. 建议去洛谷博客上看,因为两边的编辑器在有些功能上不能通用,所以之后若有删改或新增内容只在洛谷博客上弄,这边就懒得改了. 原本是针对洛谷的编辑器,不过懒 ...
- iOS设置图片名称、启动图片、防止TabBar图片和文字渲染
设置App的名称 设置App的启动图片 需要注意点是,App要杀掉重启才能显示出启动图片 2种方法防止图片被渲染 1. vc02.tabBarItem.image = [UIImage imageNa ...
- jQuery操作(二)
一: 操作元素 1. 属性操作 1.1 $("p").text() $("p").html() $(":checkbox").val() 1 ...
- Spring 循环引用(一)一个循环依赖引发的 BUG
Spring 循环引用(一)一个循环依赖引发的 BUG Spring 系列目录(https://www.cnblogs.com/binarylei/p/10198698.html) Spring 循环 ...
- 【搜索】Dungeon Master
Description You are trapped in a 3D dungeon and need to find the quickest way out! The dungeon is co ...
- [ASP.NET]使用Oracle.ManagedDataAccess的OracleParameter参数化和OracleDataAdapter模糊查询
今天写个查询员工的信息的demo遇到了2个问题 问题1.使用Oracle.ManagedDataAccess的OracleParameter参数化 OracleParameter 的使用(参数名要以: ...
- python之并发编程初级篇8
一.进程理论 1)进程介绍 .什么是进程 一个正在进行的过程,或者说是一个程序的运行过程 其实进程是对正在运行的程序的一种抽象/概括的说法 进程的概念起源操作系统,进程是操作最核心的概念之一 操作系统 ...
- python学习 day3 (3月4日)---字符串
字符串: 下标(索引) 切片[起始:终止] 步长[起始:终止:1] 或者-1 从后往前 -1 -2 -3 15个专属方法: 1-6 : 格式:大小写 , 居中(6) s.capitalize() s ...