C++算法入门练习——最短路径-多路径

现有一个共n个顶点(代表城市)、m条边(代表道路)的无向图(假设顶点编号为从0n-1),每条边有各自的边权,代表两个城市之间的距离。求从s号城市出发到达t号城市的最短路径条数和最短路径(可能有多条)。

C++算法入门练习——最短路径-多路径_第1张图片

解题思路:

Dijkstra算法的改进。

由于这里最短路径有可能有多个,因此单纯设置一个pre数组记录结点的父亲结点行不通。而也给出了解决方法,改用vector可变数组。

当我们遇见d[u]+G[u][j].weight

需要对之前的pre[newv]进行清空,重新存放。

而遇见d[u]+G[u][j].weight==d[newv]时,只需把这个新的路径结点也加入即可。

而后我们要遍历这个pre,当到达递归边界(v==s)时候,把路径加入到结果paths中保存,然后temppath弹出,继续寻找其他的路径。

而这个存储的是逆序,我们需要对每一条路径做一次逆序,然后再进行排序,从而进行输出。

完整代码如下:

#include 
#include 
#include 
#include 
using namespace std;

const int INF = 1000000000;
const int maxn = 101;
int n,t;

struct node{
	int v;
	int weight;
}; 

vector G[maxn]; 
bool isvisited[maxn] = {false};
int d[maxn];
vector pre[maxn];

void Dijkstra(int v){
	fill(d,d+maxn,INF);
	d[v] = 0;
	for(int i=0;i> paths;
vector temppath;

void minpath(int s,int v){
	if(v==s){
		temppath.push_back(v);
		paths.push_back(temppath);
		temppath.pop_back();
		return;
	}
	temppath.push_back(v);
	for(int i=0;i>n>>m>>s>>t;
	int a,b,w;
	for(int i=0;i>a>>b>>w;
		node temp;
		temp.v = b;
		temp.weight = w;
		G[a].push_back(temp);
		temp.v = a;
		G[b].push_back(temp);
	}
	Dijkstra(s);
	minpath(s,t);
	cout<";
			}
			cout<

你可能感兴趣的:(c++,算法,开发语言,图论,数据结构)