概述
题目描述
有了一张自驾旅游路线图,你会知道城市间的高速公路长度、以及该公路要收取的过路费。现在需要你写一个程序,帮助前来咨询的游客找一条出发地和目的地之间的最短路径。如果有若干条路径都是最短的,那么需要输出最便宜的一条路径。
输入
输入说明:输入数据的第1行给出4个正整数N、M、S、D,其中N(2≤N≤500)是城市的个数,顺便假设城市的编号为0~(N−1);M是高速公路的条数;S是出发地的城市编号;D是目的地的城市编号。随后的M行中,每行给出一条高速公路的信息,分别是:城市1、城市2、高速公路长度、收费额,中间用空格分开,数字均为整数且不超过500。输入保证解的存在。
输出
在一行里输出路径的长度和收费总额,数字间以空格分隔,输出结尾不能有多余空格。
#include<iostream>
#include<stack>
using namespace std;
# define max 1e9
struct duizu
{
int len;
int price;
};
class Graph {
int vexnum;
duizu** adjacency;
int* vexname;
bool* mark;
int* dst;
int* path;//路径最长的话就是走了全部节点
int start;
int end;
int edgenum;
int* jiage;
public:
Graph() {
cin >> vexnum >> edgenum >> start >> end;
vexname = new int[vexnum];
path = new int[vexnum];
dst = new int[vexnum];
jiage = new int[vexnum];
mark = new bool[vexnum];//判断是否在S中,而不是在V-S中
adjacency = new duizu* [vexnum];
for (int i = 0; i < vexnum; i++) {
adjacency[i] = new duizu[vexnum];
vexname[i] = i;
path[i] = -1;
mark[i] = false;
}
for (int i = 0; i < vexnum; i++) {
for (int j = 0; j < vexnum; j++) {
adjacency[i][j].len =max;
adjacency[i][j].price = max;
}
}
int ss, ee, ll, pp;
for (int i = 0; i < edgenum; i++) {
cin >> ss >> ee >> ll >> pp;
adjacency[ss][ee].len = ll;
adjacency[ee][ss].len = ll;
adjacency[ss][ee].price = pp;
adjacency[ee][ss].price = pp;
}
}
void dijkstra() {
int beginIndex = start;
dst[beginIndex] = 0;
mark[beginIndex] = true;
for (int i = 0; i < vexnum; i++) {
dst[i] = adjacency[beginIndex][i].len;
jiage[i] = adjacency[beginIndex][i].price;
if (adjacency[beginIndex][i].len!=max)
path[i] = beginIndex;
}
int xinjia=0;
for (int i = 1; i < vexnum; i++) {//进行n-1轮算法完成
int min = max;
for (int w = 0; w < vexnum; w++) {
if (!mark[w] && min > dst[w]) {
min = dst[w];
xinjia = w;
}
}
mark[xinjia] = true;
for (int w = 0; w < vexnum; w++) {
if (!mark[w] && dst[xinjia] + adjacency[xinjia][w].len < dst[w]) {
dst[w] = dst[xinjia] + adjacency[xinjia][w].len;
jiage[w] = jiage[xinjia] + adjacency[xinjia][w].price;
path[w] = xinjia;
}
else if(!mark[w] && dst[xinjia] + adjacency[xinjia][w].len == dst[w])
{
if (jiage[w] > jiage[xinjia] + adjacency[xinjia][w].price) {
jiage[w] = jiage[xinjia] + adjacency[xinjia][w].price;
}
}
}
}
cout << dst[end] << " " << jiage[end];
}
};
int main() {
Graph myGraph;
myGraph.dijkstra();
return 0;
}
最后
以上就是快乐镜子为你收集整理的【旅游规划】的全部内容,希望文章能够帮你解决【旅游规划】所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复