hdu 1269
强连通分量题,用tarjin算法;
这是一道很简单的tarjin算法题,基本上就是套模板;
贴代码:
- #include<cstdio>
- #include<vector>
- #include<cstring>
- #include<stack>
- #define maxn 10005
- using namespace std;
- vector<int>ve[maxn];
- int dfn[maxn],low[maxn],ans,n,m,nncount;
- bool instack[maxn],vis[maxn];
- stack<int>q;
- void tarjin(int x)
- {
- dfn[x]=low[x]=++nncount;
- vis[x]=,instack[x]=;
- q.push(x);
- int l=ve[x].size();
- for(int i=; i<l; i++)
- {
- int v=ve[x][i];
- if(!vis[v])
- {
- tarjin(v);
- low[x]=min(low[x],low[v]);
- }
- else if(instack[v])
- low[x]=min(low[x],dfn[v]);
- }
- if(low[x]==dfn[x])
- {
- ans++;
- int v;
- do
- {
- v=q.top();
- q.pop();
- instack[v]=;
- }
- while(v!=x);
- }
- }
- int main()
- {
- int x,y;
- while(scanf("%d%d",&n,&m)&&(m+n))
- {
- for(int i=; i<=n; i++)
- {
- ve[i].clear();
- instack[i]=vis[i]=;
- }
- while(!q.empty()) q.pop();
- for(int i=; i<m; i++)
- {
- scanf("%d%d",&x,&y);
- ve[x].push_back(y);
- }
- nncount=ans=;
- for(int i=; i<=n; i++)
- if(!vis[i]) tarjin(i);
- if(ans==) puts("Yes");
- else puts("No");
- }
- return ;
- }
其实这道题还可以用并查集来做;
维护两个数组,一个找儿子,一个找爸爸就行;
我也是参考别人的代码写的;
不过挺不错的,好好学习了下!
- #include<cstdio>
- using namespace std;
- int f[],d[],n,m;
- int find1(int x)
- {
- if(x!=&&f[x]!=x)
- f[x]=find1(f[x]);
- return f[x];
- }
- int find2(int x)
- {
- if(x!=&&d[x]!=x)
- d[x]=find2(d[x]);
- return d[x];
- }
- void uni(int x,int y)
- {
- if(x>) f[x]=find1(y);
- if(y>) d[y]=find2(x);
- }
- bool judge()
- {
- for(int i=; i<=n; i++)
- if(find1(i)!=||find2(i)!=)
- return ;
- return ;
- }
- int main()
- {
- int x,y;
- while(scanf("%d%d",&n,&m)&&(n+m))
- {
- for(int i=; i<=n; i++)
- f[i]=i,d[i]=i;
- for(int i=; i<m; i++)
- {
- scanf("%d%d",&x,&y);
- uni(x,y);
- }
- if(judge()) puts("No");
- else puts("Yes");
- }
- return ;
- }
hdu 1269的更多相关文章
- HDU 1269 迷宫城堡(强连通)
HDU 1269 迷宫城堡 pid=1269" target="_blank" style="">题目链接 题意:中文题 思路:强连通模板题 代 ...
- HDU 1269 迷宫城堡 (Kosaraju)
题目链接:HDU 1269 Problem Description 为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个房间(N<=10000)和M条通道(M<=100000), ...
- Hdu 1269 强连通判定
题目链接 迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total S ...
- 连通图模板(HDU 1269)
http://acm.hdu.edu.cn/showproblem.php?pid=1269 题目大意:给定一个图,判断该图是否是强连通图.(强连通图为从任意一点出发,可到达其他所有点).深搜的Tar ...
- HDU 1269:迷宫城堡(强连通)
http://acm.hdu.edu.cn/showproblem.php?pid=1269 题意:确定是否是一个强连通图. 思路:裸的tarjan算法. #include <cstdio> ...
- hdu 1269 迷宫城堡
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1269 迷宫城堡 Description 为了训练小希的方向感,Gardon建立了一座大城堡,里面有N个 ...
- hdu - 1269 迷宫城堡 (强连通裸题)
http://acm.hdu.edu.cn/showproblem.php?pid=1269 判断一个图是不是强连通,缩点之后判断顶点数是不是为1即可. #include <iostream&g ...
- hdu 1269 迷宫城堡(trajan判环)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1269 题意:略 题解:trajan模版直接求强连通分量. #include <iostream& ...
- hdu 1269 迷宫城堡 强连通分量
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
- HDU 1269 迷宫城堡(判断有向图强连通分量的个数,tarjan算法)
迷宫城堡 Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)Total Submis ...
随机推荐
- 关于ProgressBar的美化问题
Android自带的ProgressBar其实也算不上丑陋,但是如果所有的App都使用一个模式的ProgressBar,那么估计用户就要崩溃了,打开任何一个App,擦,进度条都一模一样..有鉴于此,我 ...
- oracle学习----特殊的连接方式
1.笛卡儿积 merge join cartesion SQL> select ename,dname from emp,dept; 已选择56行. 执行计划------------------ ...
- Java基础知识强化之IO流笔记40:字符流缓冲流之特殊功能 [ newLine() / readLine() ]
1. 字符缓冲流的特殊方法 BufferedWriter: public void newLine():根据系统来决定换行符 BufferedReader: public String readLin ...
- last_9t's_ramsey
cannot finish his face
- Scala函数字面量
Scala中函数为头等公民,你不仅可以定义一个函数然后调用它,而且你可以写一个未命名的函数字面量,然后可以把它当成一个值传递到其它函数或是赋值给其它变量.下面的例子为一个简单的函数字面量(参考整数字面 ...
- 盘点 Github 所用到的开源项目
http://www.php100.com/html/it/mobile/2014/0401/6736.html 在致力于开源事业的同时,Github也使用一些非常优秀的开源项目的来打造自己的平台与服 ...
- .Net之美读书系列(一):委托与事件
开启新的读书之旅,这次读的书为<.Net之美:.Net关键技术深入解析>. 我是选择性阅读的,把一些自己觉得容易忘记的,或者比较重要的知识点记录下来,以便以后能方便呢查阅. 尊重书本原作者 ...
- web services 接口测试方法
public class Test { public static void main(String[] args) { JaxWsProxyFactoryBean factory = new Jax ...
- JDBC——数据层DAO
DAO:Data Access Object DAO 数据层 Service 逻辑业务层 View 视图层 entity 实体层 实现增.删.改.查的数据层 public class EmpDA ...
- Codevs 3990 中国余数定理 2
3990 中国余数定理 2 时间限制: 1 s 空间限制: 1000 KB 题目等级 : 白银 Silver 传送门 题目描述 Description Skytree神犇最近在研究中国博大精深的数学. ...