最短路径与Floyed算法
来源:互联网 发布:python冒泡排序算法 编辑:程序博客网 时间:2024/06/05 08:37
一个矩阵cost[N][N],cost[i][j]表示从i到j的路径长度,如果不通的话就是-1;现在给你一个矩阵,希望查询出从p到q的最短路径长度,不存在路的话输出“no”
是的,这是一个最短路径问题,用单源最短路径(Dijkstra)和多源最短路径(Floyd)算法都可以实现,时间要取决于N和Q,因为单源最短路径是每次查询都要来一遍,但每一遍是O(n2),而多源最短路径针对一个矩阵只需要运行一次,每次查询不必重新算,不过单次的时间是O(n3);
上一段代码看看
const int INF = (1<<20);int cost[1000][1000];void Floyd(int n){ for(int k =1;k<=n;k++) for(int i = 1;i<=n;i++) for(int j = 1; j<=n;j++) cost[i][j] = min(cost[i][j], cost[i][k]+cost[k][j]);}int main(){ int N,Q,vi,vj; while(~scanf("%d%d",&N,&Q)) { memset(cost,0,sizeof(cost)); for(int i = 1;i<=N;i++) for(int j = 1;j<=N;j++) { scanf("%d",&cost[i][j]); if(cost[i][j] == -1) cost[i][j] = INF;//这里为了避免负回路的出现影响判断 } Floyd(N); while(Q--) { scanf("%d%d",&vi,&vj); if(cost[vi][vj]>=INF||vi==vj)//不通的情况 printf("no\n"); else printf("%d\n",cost[vi][vj]); } }}
0 0
- 最短路径与Floyed算法
- 最短路径(Floyed算法)
- 浅谈最短路径Floyed算法(c)
- 最短路径之Floyed算法
- 最短路径之Floyed-Warshall算法
- Floyed算法实现最短路径
- Floyed算法求两点之间的最短路径
- ACM-Floyed算法求两点之间的最短路径
- 图的最短路径Dijkstra+Floyed算法
- POJ 2253 Frogger 最短路径 Floyed-Warshall算法
- ZOJ 1082 (最短路径 Floyed)
- 最短路径(Dijikstra和Floyed)
- poj 1125 (floyed 最短路径)
- 最短路径 dijkstra bellford floyed
- 【模板】最短路径(Floyed&SPFA )
- 图论算法----最短路径Floyed算法和Dijkstra算法详解
- 弗洛伊德算法Floyed(求各顶点间最短路径):可打印最短路径
- 【图】最短路径——Floyed算法和Dijkstra算法
- Socket总结 & node搭建简单的http服务器
- 线程(1)——操作系统和线程原理
- 九度OJ题目1035:找出直系亲属
- HTTP Session和Cookie工作原理
- linux Ubuntu无法启动 报错:UNEXPECTED INCONSISTENCY;
- 最短路径与Floyed算法
- win7下ssh免密连接git服务器
- Ubuntu14.04下采用PPTP搭建VPN服务
- [MySQL]mac修改root默认密码
- 用HttpGet和HttpClient网路请求数据
- 【洛谷 1054】[NOIP2005] 等价表达式
- 基础总结篇之一:Activity生命周期
- HashMap<string, ...> 能有多快
- 模拟退火法---飞机巡航问题