网站的分类有哪些内容,全球最大设计网站,做纪念品网站,wordpress 3.6升级4.7有了一张自驾旅游路线图#xff0c;你会知道城市间的高速公路长度、以及该公路要收取的过路费。现在需要你写一个程序#xff0c;帮助前来咨询的游客找一条出发地和目的地之间的最短路径。如果有若干条路径都是最短的#xff0c;那么需要输出最便宜的一条路径。
输入格式: …有了一张自驾旅游路线图你会知道城市间的高速公路长度、以及该公路要收取的过路费。现在需要你写一个程序帮助前来咨询的游客找一条出发地和目的地之间的最短路径。如果有若干条路径都是最短的那么需要输出最便宜的一条路径。
输入格式: 输入说明输入数据的第1行给出4个正整数N、M、S、D其中N2≤N≤500是城市的个数顺便假设城市的编号为0~(N−1)M是高速公路的条数S是出发地的城市编号D是目的地的城市编号。随后的M行中每行给出一条高速公路的信息分别是城市1、城市2、高速公路长度、收费额中间用空格分开数字均为整数且不超过500。输入保证解的存在。
输出格式: 在一行里输出路径的长度和收费总额数字间以空格分隔输出结尾不能有多余空格。
输入样例: 4 5 0 3 0 1 1 20 1 3 2 30 0 3 4 10 0 2 2 20 2 3 1 20 输出样例: 3 40
这篇没有注释看不懂代码的移步我的甲级专栏里的1003 Emergency (25 分)那个有详细的注释。
//迪杰斯特拉算法求7-3 旅游规划 (25 分)
#include stdio.h
#include string.h
#includestdbool.h
#define maxn 0x3f3f3f3f
int n;
int L[1001][1001]; //城市之间的距离
int W[1001][1001]; //城市之间的收费
int LL[1001]; //到起点的最近距离
int WW[1001]; //到起点的最近距离的收费
int flag[1001]; //是否走过
void Dijkstra(int x)
{memset(flag, false, sizeof(flag));memset(LL,maxn,sizeof(LL));LL[x] 0;for (int j 0; j n; j){int u -1, min maxn;for (int i 0; i n; i){if (flag[i] false LL[i] min){u i;min LL[i];}}if (u -1)return;flag[u] true;for (int i 0; i n; i){if (L[u][i] ! 0 flag[i] false){if (L[u][i] LL[u] LL[i]){LL[i] L[i][u] LL[u];WW[i] W[i][u] WW[u];}else if (L[u][i] LL[u] LL[i]){if (WW[u] W[u][i] WW[i]){WW[i] W[u][i] WW[u];}}}}}
}
int main()
{int m, s, d;scanf(%d %d %d %d, n, m, s, d);memset(L, maxn, sizeof(L));while (m--){int a, b, l, w;scanf(%d %d %d %d, a, b, l, w);L[a][b] l, L[b][a] l;W[a][b] w, W[b][a] w;}Dijkstra(s);printf(%d %d, LL[d], WW[d]);
}