




已阅读5页,还剩4页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
典型算法与ACM题目解析(02)有向图的强连通分量上一篇:典型算法与ACM题目解析(01)寻找最大流的标号法下一篇:关于STL中优先队列的用法作者:dzf阅读次数:87时间:2006-11-27 21:23:49算法园地这道题是POJ的2186题,题意是说,有一群牛,总数为N(N2,2=3,3=1,所以这解这道题最好的方法是使用有向图的强连通分量。在同一个强连通分量里的所有的牛之间是互相仰慕的,我们将其缩为一点,并且只记录这一点的牛的数量,如果有最受欢迎的牛存在,那么这个图将是连通图,并且出度为零的点只有一个,我们可以用并查集来判是否连通,然后计算每个节点的出度,即可求出最受欢迎的牛的数量。求强连通分量有三种算法,分别是Kosaraju算法,Gabow算法和Tarjan算法,其中Kosaraju算法要对原图和逆图都进行一次DFS,而另外两种算法只要DFS一次就可以了用了Gabow算法和Kosaraju算法各写了一遍在时间上Gabow算法是122ms,Kosaraju算法是61ms理论上Gabow算法要比Kosaraju快些的,因为Gabow算法只对原图进行一次DFS而Kosaraju要进行两次Gabow反而慢的原因可能是我用了STL里的stackPS:我没看懂Gabow算法,完全是对着书上写的代码如下:Kosaraju算法/* 求有向图的强连通分量的Kosarajus algorithm By Sempr - 2006.06.16*/#include #include #define G_size 100000#define V_size 11000typedef struct Graph int id; int next; Graph;typedef struct Edge int s, e; Edge;Edge EG_size;Graph GAG_size, GTG_size;int N, M;int G_end;int orderV_size, idV_size, visV_size, inV_size;int cnt, scnt, pos;void Insert(int s, int e) /建立原图和逆图 int p; p = s; while (GAp.next) p = GAp.next; GAG_end.id = e; GAp.next = G_end; p = e; while (GTp.next) p = GTp.next; GTG_end.id = s; GTp.next = G_end; G_end+;void DFST(int x) /对逆图进行搜索 int p, q; visx = 1; p = GTx.next; while (p) q = GTp.id; if (!visq) DFST(q); p = GTp.next; ordercnt+ = x;void DFSA(int x) /对原图进行搜索 int p, q; visx = 1; idx = cnt; p = GAx.next; while (p) q = GAp.id; if (!visq) DFSA(q); p = GAp.next; void Solve() /主要过程 int s, e; int i; memset(GA, 0, sizeof(GA); memset(GT, 0, sizeof(GT); memset(E, 0, sizeof(E); G_end = N + 1; for (i = 0; i M; i+) scanf(%d %d, &s, &e); Ei.s = s - 1; Ei.e = e - 1; Insert(s - 1, e - 1); memset(vis, 0, sizeof(vis); cnt = 0; for (i = 0; i = 0; i-) if (!visorderi) DFSA(orderi); cnt+; for (i = 0; i M; i+) s = idEi.s; e = idEi.e; if (s != e) ins+; scnt = cnt; cnt = 0; for (i = 0; i scnt; i+) if (ini = 0) pos = i; cnt+; if (cnt != 1) printf(0n); else cnt = 0; for (i = 0; i N; i+) if (inidi = pos) cnt+; printf(%dn, cnt); int main() while (EOF != scanf(%d %d, &N, &M) Solve(); return 0;Gabow算法/* 求有向图的强连通分量的Gabows algorithm By Sempr - 2006.06.14*/#include #include #include #define size 11000using namespace std;int N, M;typedef struct Node int id; int next; Node;typedef struct Edge int s, e;Edge;Edge Esize * 6;Node Gsize * 7;int presize, idsize;typedef stack Stack;Stack S, path;int end;int cnt, scnt;int vissize;int insize;void Insert(int s, int e) int p = s; while (Gp.next) p = Gp.next; if (Gp.id = e) return; Gp.next = end; Gend.id = e; end+;void scR(int w) int v; int p, t; prew = cnt+; S.push(w); path.push(w); p = Gw.next; while (p) t = Gp.id; p = Gp.next; if (pret = -1) scR(t); else if (idt = -1) while (prepath.top() pret) path.pop(); if (path.top() = w) path.pop(); else return; do idv = S.top() = scnt; S.pop(); while (v != w); scnt+;void Gabow() int i; memset(pre, -1, sizeof(pre); memset(id, -1, sizeof(id); cnt = 0; scnt = 0; while (!S.empty() S.pop(); while (!path.empty() path.pop(); for (i = 1; i cnt) cnt = d; while (p) if (preGp.id != 1) DFS(Gp.id, d); p = Gp.next; void Solve() int i, s, e; int pos; memset(G, 0, sizeof(G); end = N + 10; memset(in, 0, sizeof(in); for (i = 0; i M; i+) scanf(%d %d, &s, &e); Ei.s = s; Ei.e = e; Insert(s, e); Gabow(); memset(G, 0, sizeof(G); memset(pre, 0, sizeof(pre); end = scnt + 10; for (i = 0; i M; i+) s = idEi.s; e = idEi.e; if (s != e) ins+; cnt = 0; for (i = 0; i scnt; i+) if (ini = 0) pos = i;
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年事业单位招聘考试综合类职业能力倾向测验真题模拟试卷(石家庄)
- 2025年安徽省事业单位招聘考试教师招聘生物学科专业知识试卷及答案
- 呼吸机的考试试题及答案
- 我的探险经历记事类作文(14篇)
- 衡水五升六考试题及答案
- 新解读《GB-T 39316.3-2020军民通 用资源 元数据 第3部分:器材类 航材》
- 2025年中国无绳手持式花园电动工具行业市场分析及投资价值评估前景预测报告
- 2025国考晋中市财务管理岗位申论模拟题及答案
- 2025国考应急部行测言语理解与表达预测卷及答案
- 胃肠疾病早期筛查-洞察与解读
- 医美培训课件
- 空压机操作安全培训
- 手术体位侧卧摆放
- 大型聚会安保人员配置方案
- 国防动员课件教学课件
- 江苏省南通市2024-2025学年七年级上学期期中英语试题(含答案不含听力原文及听力音频)
- 统编语文四年级上册第六单元教材解读及集体备课
- 课程纲要(知识清单)人教版美术五年级上册
- 医学信息集成标准与技术 课件 第六章 医疗健康信息集成规范IHE
- (正式版)QC∕T 1207-2024 燃料电池发动机用空气压缩机
- 2024年辽宁沈阳市近海控股集团招聘24人公开引进高层次人才和急需紧缺人才笔试参考题库(共500题)答案详解版
评论
0/150
提交评论