9-最短路径(dijkstra)
参考博客:http://www.wutianqi.com/?p=1890
#include <iostream>
using namespace std;
#define max 1<<20 //无穷大
int pre[100]; //p[i]存放路径中i前面一个点
int dis[100]; //到远点的距离
int c[100][100]; //每个点间的距离
int dijkstra(int n, int v){ //v是源点,n是点的个数
bool s[100] = {0}; //表示是否在原点集合中
for(int i = 1; i <= n; i++){ //初始化dis[],s[],pre[]
dis[i] = c[i][v];
s[i] = 0;
if(dis[i] != max){
pre[i] = v;
}
else
pre[i] = 0;
}
dis[v] = 0;
s[v] = 1;
for(int i = 2; i <= n; i++){
int temp = max, u = v;
for(int j = 1; j <= n; j++){ //找到最小的直达源点的点
if(!s[j] && temp > dis[j]){
temp = dis[j];
u = j;
}
}
// cout << "u: " << u << endl;
s[u] = 1; //表示将找的的点放入源点集合
for(int j = 1; j <= n; j++){ //更新u的临边到远点的距离
if(!s[j] && c[j][u] < max){
// cout << "jJJ" << endl;
if(dis[j] > c[j][u] + dis[u]){
dis[j] = c[j][u] + dis[u];
pre[j] = u;
// cout << "j:" << j << endl;
}
}
}
}
return 1;
}
int luxian(int v, int u){ //查找点源点v到u点的距离
int p;
int count = 0, a[100] = {u};
p = pre[u];
while(p != v){
a[++count] = p;
p = pre[p];
}
a[++count] = v;
cout << "count" << count << endl;
for(int i = count; i >= 0; i--)
cout << a[i] << " -> ";
}
int main(){
ios::sync_with_stdio(false);
int n, line, a, b, len;
cin >> n >> line;
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
c[i][j] = max;
cout << max;
for(int i = 1; i <= line; i++){
cin >> a >> b >> len;
if(len < c[a][b]){
c[a][b] = len;
c[b][a] = len;
}
}
for(int i = 1; i <= n; i++)
dis[i] = max;
for(int i = 1; i <= n; i++){
for(int j = 1; j <= n; j++)
cout << c[i][j] << " ";
cout << endl;
}
dijkstra(n, 1);
luxian(1, n);
cout << endl;
cout << "1到n的最小距离: " << dis[n] << endl;
return 0;
}
9-最短路径(dijkstra)的更多相关文章
- 最短路径 dijkstra
最短路径 dijkstra #include <stdio.h> #include <string.h> #include <limits.h> #define M ...
- 网络最短路径Dijkstra算法
最近在学习算法,看到有人写过的这样一个算法,我决定摘抄过来作为我的学习笔记: <span style="font-size:18px;">/* * File: shor ...
- c/c++ 图的最短路径 Dijkstra(迪杰斯特拉)算法
c/c++ 图的最短路径 Dijkstra(迪杰斯特拉)算法 图的最短路径的概念: 一位旅客要从城市A到城市B,他希望选择一条途中中转次数最少的路线.假设途中每一站都需要换车,则这个问题反映到图上就是 ...
- 单源最短路径Dijkstra算法,多源最短路径Floyd算法
1.单源最短路径 (1)无权图的单源最短路径 /*无权单源最短路径*/ void UnWeighted(LGraph Graph, Vertex S) { std::queue<Vertex&g ...
- 最短路径——Dijkstra算法和Floyd算法
Dijkstra算法概述 Dijkstra算法是由荷兰计算机科学家狄克斯特拉(Dijkstra)于1959 年提出的,因此又叫狄克斯特拉算法.是从一个顶点到其余各顶点的最短路径算法,解决的是有向图(无 ...
- 最短路径-Dijkstra算法与Floyd算法
一.最短路径 ①在非网图中,最短路径是指两顶点之间经历的边数最少的路径. AE:1 ADE:2 ADCE:3 ABCE:3 ②在网图中,最短路径是指两顶点之间经历的边上权值之和最短的路径 ...
- 数据结构实验之图论七:驴友计划 ( 最短路径 Dijkstra 算法 )
数据结构实验之图论七:驴友计划 Time Limit: 1000 ms Memory Limit: 65536 KiB Submit Statistic Discuss Probl ...
- 最短路径——Dijkstra算法以及二叉堆优化(含证明)
一般最短路径算法习惯性的分为两种:单源最短路径算法和全顶点之间最短路径.前者是计算出从一个点出发,到达所有其余可到达顶点的距离.后者是计算出图中所有点之间的路径距离. 单源最短路径 Dijkstra算 ...
- 有向网络(带权的有向图)的最短路径Dijkstra算法
什么是最短路径? 单源最短路径(所谓单源最短路径就是只指定一个顶点,最短路径是指其他顶点和这个顶点之间的路径的权值的最小值) 什么是最短路径问题? 给定一带权图,图中每条边的权值是非负的,代表着两顶点 ...
- 理解最短路径-Dijkstra算法
最短路径—Dijkstra算法和Floyd算法 透彻理解迪杰斯特拉算法 Dijkstra算法的使用条件:图中不存在负权边. ---------------------------有待验证------- ...
随机推荐
- windows挂载gluseter NFS卷
windows下挂载gluster提供的NFS卷 服务器端的配置: 首先配置好NFS共享,找一台linux试一下,确保挂载成功.linux客户端执行:mount.nfs 10.33.70.20:tes ...
- Mybatis通过colliection属性递归获取菜单树
1.现有商品分类数据表category结构如下,三个字段都为varchar类型 2.创建商品分类对应的数据Bean /** * */ package com.xdw.dao; import java. ...
- SyntaxError: Non-ASCII character ‘\xe5′ in file
在写一个抓取网页的小脚本,运行起来总是出现这个错误 查了下Python的默认编码文件是用的ASCII码,你将文件存成了UTF-8也没用,解决办法很简单 只要在文件开头加入 # -*- coding: ...
- swagger配置
1.pom.xml <!--swagger2--> <dependency> <groupId>io.springfox</groupId> <a ...
- smyfony2 增删改查
1查询和修改
- HTML5 Canvas ( 扩展context('2d') ) CanvasRenderingContext2D.prototype.你的方法名
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- DOS系统变量
%ALLUSERSPROFILE% : 列出所有用户Profile文件位置.%APPDATA% : 列出应用程序数据的默认存放位置.%CD% : 列出当前目录.%CLIENTNAME% : 列出联接到 ...
- 根据img的url 判断img的图片大小
// 图片地址 后面加时间戳是为了避免缓存 var img_url = 'http://www.qttc.net/static/upload/2013/13643608813441.jpg?'+Dat ...
- c++11新特性总结(转)
1.类型与变量相关 1.1.nullptr: 取代了NULL,专用于空指针 1.2.constexpr: 近似const, 可以修饰变量,也可以修饰函数, 修饰变量如: const int globa ...
- 推荐的 MongoDB 安装文档
简介: MongoDB 是一个由 C++ 语言编写的基于分布式文件存储的数据库,是目前最像关系型数据库的非关系型数据库. 最近写爬虫, 思来想去觉得还是用 MongoDB 比较方便. 一.安装 # 官 ...