AOE网上的关键路径(最长路径 + 打印路径)
题目描述
一个无环的有向图称为无环图(Directed Acyclic Graph),简称DAG图。
AOE(Activity On Edge)网:顾名思义,用边表示活动的网,当然它也是DAG。与AOV不同,活动都表示在了边上,如下图所示:
如上所示,共有11项活动(11条边),9个事件(9个顶点)。整个工程只有一个开始点和一个完成点。即只有一个入度为零的点(源点)和只有一个出度为零的点(汇点)。
关键路径:是从开始点到完成点的最长路径的长度。路径的长度是边上活动耗费的时间。如上图所示,1 到2 到 5到7到9是关键路径(关键路径不止一条,请输出字典序最小的),权值的和为18。
输入
输出
示例输入
- 9 11
- 1 2 6
- 1 3 4
- 1 4 5
- 2 5 1
- 3 5 1
- 4 6 2
- 5 7 9
- 5 8 7
- 6 8 4
- 8 9 4
- 7 9 2
示例输出
- 18
- 1 2
- 2 5
- 5 7
- 7 9
- 好久做过的题了,不过今天拿出来看看觉得这个题挺好,它是逆向建图和打印路径,求最长路径;
最长路径用SPFA求解,但注意初始化为最小。
- #include<stdio.h>
- #include<string.h>
- #include<iostream>
- #include<queue>
- #include<vector>
- using namespace std;
- const int INF = 0x3f3f3f3f;
- const int MAX = ;
- struct edge
- {
- int to,w;
- };
- struct node
- {
- int indegree;
- int outdegree;
- }V[MAX+];
- int n,m;
- int inque[MAX+],dis[MAX+];
- int pre[MAX+];
- vector<edge>map[MAX+];
- void spfa(int s)
- {
- queue<int>que;
- memset(inque,,sizeof(inque));
- for(int i = ; i <= n; i++)
- dis[i] = -INF;//注意初始化
- dis[s] = ;
- que.push(s);
- inque[s] = ;
- while(!que.empty())
- {
- int u = que.front();
- que.pop();
- inque[u] = ;
- for(int i = ; i < map[u].size(); i++)
- {
- int to = map[u][i].to;
- if(dis[u] > -INF && (dis[to] < map[u][i].w + dis[u] || (dis[to] == map[u][i].w + dis[u] && u < pre[to])))
- {
- dis[to] = map[u][i].w + dis[u];
- pre[to] = u;
- if(inque[to] == )
- {
- que.push(to);
- inque[to] = ;
- }
- }
- }
- }
- }
- int main()
- {
- int u,v,w,s,t;
- while(~scanf("%d %d",&n,&m))
- {
- memset(pre, 0x3f, sizeof(pre));
- for(int i = ; i <= n; i++)
- map[i].clear();
- for(int i = ; i <= n; i++)
- {
- V[i].indegree = ;
- V[i].outdegree = ;
- }
- for(int i = ; i <= m; i++)
- {
- //逆向建图
- scanf("%d %d %d",&u,&v,&w);
- map[v].push_back((struct edge){u, w});
- V[v].outdegree++;
- V[u].indegree++;
- }
- for(int i = ; i <= n; i++)
- {
- if(V[i].indegree == )
- s = i;
- if(V[i].outdegree == )
- t = i;
- }
- spfa(s);
- printf("%d\n",dis[t]);
- int x = t;
- //打印路径
- while(x != s)
- {
- printf("%d %d\n", x, pre[x]);
- x = pre[x];
- }
- }
- return ;
- }
AOE网上的关键路径(最长路径 + 打印路径)的更多相关文章
- SDUT 2498 AOE网上的关键路径
AOE网上的关键路径 Time Limit: 1000MS Memory Limit: 65536KB Submit Statistic Problem Description 一个无环的有向图称为无 ...
- sdut AOE网上的关键路径(spfa+前向星)
http://acm.sdut.edu.cn/sdutoj/showproblem.php?pid=2498&cid=1304 题目描述 一个无环的有向图称为无环图(Directed Acyc ...
- 数据结构实验之图论十一:AOE网上的关键路径【Bellman_Ford算法】
Problem Description 一个无环的有向图称为无环图(Directed Acyclic Graph),简称DAG图. AOE(Activity On Edge)网:顾名思义,用边 ...
- SDUTOJ 2498 数据结构实验之图论十一:AOE网上的关键路径
题目链接:http://acm.sdut.edu.cn/onlinejudge2/index.php/Home/Index/problemdetail/pid/2498.html 题目大意 略. 分析 ...
- sdut 2498【aoe 网上的关键路径】
http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2498 代码超时怎么破: #include< ...
- SDUT 2498-AOE网上的关键路径(spfa+字典序路径)
AOE网上的关键路径 Time Limit: 1000ms Memory limit: 65536K 有疑问?点这里^_^ 题目描写叙述 一个无环的有向图称为无环图(Directed Acycl ...
- SDUT-2498_AOE网上的关键路径
数据结构实验之图论十一:AOE网上的关键路径 Time Limit: 2000 ms Memory Limit: 65536 KiB Problem Description 一个无环的有向图称为无环图 ...
- zoj 3088 Easter Holidays(最长路+最短路+打印路径)
Scandinavians often make vacation during the Easter holidays in the largest ski resort Are. Are prov ...
- 最长公共子序列Lcs(打印路径)
给出两个字符串A B,求A与B的最长公共子序列(子序列不要求是连续的). 比如两个串为: abcicba abdkscab ab是两个串的子序列,abc也是,abca也是,其中abca是这 ...
随机推荐
- [转] 在React Native中使用ART
http://bbs.reactnative.cn/topic/306/%E5%9C%A8react-native%E4%B8%AD%E4%BD%BF%E7%94%A8art 前半个月捣腾了一下Rea ...
- [转] Scale-up 和Scale-out的区别
http://www.cnblogs.com/spork/archive/2009/12/29/1634766.html 来自原小站,曾经迷糊过的东西,表上来,希望对正在迷糊或即将迷糊的人有帮助. 谈 ...
- Java实现对文件的上传下载操作
通过servlet,实现对文件的上传功能 1.首先创建一个上传UploadHandleServlet ,代码如下: package me.gacl.web.controller; import jav ...
- ActionScript:Resampling PCM data
使用基于flash的麦克风录音,如果想在获取完PCM采样数据后,通过Sound马上回放,必须经过resampling.(注意:如果录音是采用的44KHz的话,则不需要) 因此,需要as实现一个简便的函 ...
- 同一台电脑上安装两个tomcat服务器
1.下载免安装版tomcat,解压成tomcat1.tomcat2: 2.修改tomcat2中conf下server.xml文件如下: <Server port="8005" ...
- iOS 8 Handoff 开发指南
(原文:Working with Handoff in iOS 8 作者:Gabriel Theodoropoulos 译者:半圆圆) 我想用下面这一个美妙的场景来开始这篇教程:假象一下你正在Mac上 ...
- iOS app闪退的一般原因
1.函数无限递归爆栈(表视图返回Cell和返回行高的方法互相调用)2.某对象无法解析某个方法(没做类型转换.或者代理没实现某个方法)3.访问了某个已经被释放的对象(ARC之后不太有)4.从Bundle ...
- UITableViewCell 添加长按手势
UILongPressGestureRecognizer *lpgr = [[UILongPressGestureRecognizer alloc] initWithTarget:self actio ...
- Swift中可选类型(Optional)的用法 以及? 和 ! 的区别 (转载博客,知识分享)
本文转载自:代码手工艺人的博客,原文名称:Swift之 ? 和 ! Swift语言使用var定义变量,但和别的语言不同,Swift里不会自动给变量赋初始值,也就是说变量不会有默认值,所以要求使用变量之 ...
- [转]Delphi Form的释放和隐藏:free,hide,close
form.Free - 释放Form占用的所有资源.Free后,Form指针不能再使用,除非对Form重新赋值. form.Hide - 隐藏Form.可以调用form.Show再一次显示. form ...