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

来源:互联网 发布:qq飞车神圣天使数据 编辑:程序博客网 时间:2024/05/17 23:47

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

Value Passing

Time Limit: 1000MS Memory Limit: 65536KBSubmit Statistic DiscussProblem Description做为一个资深驴友,小新有一张珍藏的自驾游线路图,图上详细的标注了全国各个城市之间的高速公路距离和公路收费情况,现在请你编写一个程序,找出一条出发地到目的地之间的最短路径,如果有多条路径最短,则输出过路费最少的一条路径。Input连续T组数据输入,每组输入数据的第一行给出四个正整数N,M,s,d,其中N(2 <= N <= 500)是城市数目,城市编号从0N-1,M是城市间高速公路的条数,s是出发地的城市编号,d是目的地的城市编号;随后M行,每行给出一条高速公路的信息,表示城市1、城市2、高速公路长度、收费额,中间以空格间隔,数字均为整数且不超过500,输入数据均保证有解。 Output在同一行中输出路径长度和收费总额,数据间用空格间隔。 Example Input14 5 0 30 1 1 201 3 2 300 3 4 100 2 2 202 3 1 20Example Output3 40HintAuthorxam SDUTACM运维技术中心.Wed Aug 09 2017 20:39:50 GMT+0800 (中国标准时间) Copyright © 2013-2017 SDUTACM Team. All Rights Reserved.
#include <iostream>#include <limits.h>#include <stdio.h>#include <string.h>#include <queue>#include <stdlib.h>#define OK 1#define OVERFLOW -1#define SIZE 100using namespace std;struct node{    int len;    int cost;}map[510][510],small;int visit[510];int n,m,s,d;int step = 0;int money = 0;void dfs(int s,int n){    if(s==d)    {        if(step<small.len||(step==small.len&&money<small.cost))        {            small.len = step;            small.cost = money;        }    }    for(int i = 0;i<n;i++)    {        if(map[s][i].len!=INT_MAX&&visit[i]==0)        {            visit[i] = 1;            step += map[s][i].len;            money += map[s][i].cost;            dfs(i,n);            step -= map[s][i].len;            money -= map[s][i].cost;            visit[i] = 0;        }    }}int main(){    int t;    cin>>t;    while(t--)    {        step = 0;        money = 0;        small.cost = INT_MAX;        small.len = INT_MAX;        memset(visit,0,sizeof(visit));        for(int i = 0;i<510;i++)        {            for(int j = 0;j<510;j++)            {                map[i][j].cost = INT_MAX;                map[i][j].len = INT_MAX;            }        }        scanf("%d %d %d %d",&n,&m,&s,&d);        for(int i = 0;i<m;i++)        {            int a,b,c,d;            scanf("%d %d %d %d",&a,&b,&c,&d);            if(c<map[a][b].len||(c==map[a][b].len&&d<map[a][b].cost))            {                map[a][b].len = c;                map[a][b].cost = d;                map[b][a].len = c;                map[b][a].cost = d;            }        }        visit[s] = 1;        dfs(s,n);        printf("%d %d\n",small.len,small.cost);    }}/***************************************************User name: rj160206武志祥Result: AcceptedTake time: 0msTake Memory: 2236KBSubmit time: 2017-07-29 11:04:07****************************************************/
原创粉丝点击