您的位置:首页 > 理论基础 > 数据结构算法

数据结构实验之图论七:驴友计划

2016-08-18 16:56 211 查看


数据结构实验之图论七:驴友计划



Time Limit: 1000MS Memory limit: 65536K


题目描述

做为一个资深驴友,小新有一张珍藏的自驾游线路图,图上详细的标注了全国各个城市之间的高速公路距离和公路收费情况,现在请你编写一个程序,找出一条出发地到目的地之间的最短路径,如果有多条路径最短,则输出过路费最少的一条路径。


输入

连续T组数据输入,每组输入数据的第一行给出四个正整数N,M,s,d,其中N(2 <= N <= 500)是城市数目,城市编号从0~N-1,M是城市间高速公路的条数,s是出发地的城市编号,d是目的地的城市编号;随后M行,每行给出一条高速公路的信息,表示城市1、城市2、高速公路长度、收费额,中间以空格间隔,数字均为整数且不超过500,输入数据均保证有解。 


输出

在同一行中输出路径长度和收费总额,数据间用空格间隔。 


示例输入

1
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


#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define INF 0x3f3f3f3f
using namespace std;
struct node
{
int l;
int w;
}a[510][510];

void floyd(int n)
{
int k, i, j;
for(k=0; k<n; k++)
for(i=0; i<n; i++)
for(j=0; j<n; j++)
{
if(a[i][j].l>a[i][k].l+a[k][j].l)
{
a[i][j].l=a[i][k].l+a[k][j].l;
a[i][j].w=a[i][k].w+a[k][j].w;
}
if(a[i][j].l==a[i][k].l+a[k][j].l)
{
if(a[i][j].w>a[i][k].w+a[k][j].w)
a[i][j].w=a[i][k].w+a[k][j].w;
}

}

}

int main()
{
int t, n, m, i, j, s, d;
scanf("%d", &t);
while(t--)
{
scanf("%d %d %d %d", &n, &m, &s, &d);
for(i=0; i<n; i++)
for(j=0; j<n; j++)
{
if(i!=j)
{
a[i][j].l = INF;
a[i][j].w = INF;
}
else
{
a[i][j].l = 0;
a[i][j].w = 0;
}
}
int v1, v2, length, cost;
for(i=0; i<m; i++)
{
scanf("%d %d %d %d", &v1, &v2, &length, &cost);
a[v1][v2].l = length;
a[v1][v2].w = cost;
a[v2][v1] = a[v1][v2];
}
floyd(n);
printf("%d %d\n", a[s][d].l, a[s][d].w);

}
}

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: