数据结构实验之图论七:驴友计划
来源:互联网 发布:qq飞车神圣天使数据 编辑:程序博客网 时间:2024/05/17 23:47
数据结构实验之图论七:驴友计划
Value PassingTime Limit: 1000MS Memory Limit: 65536KBSubmit Statistic DiscussProblem Description做为一个资深驴友,小新有一张珍藏的自驾游线路图,图上详细的标注了全国各个城市之间的高速公路距离和公路收费情况,现在请你编写一个程序,找出一条出发地到目的地之间的最短路径,如果有多条路径最短,则输出过路费最少的一条路径。Input连续T组数据输入,每组输入数据的第一行给出四个正整数N,M,s,d,其中N(2 <= N <= 500)是城市数目,城市编号从0~N-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****************************************************/
阅读全文
0 0
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 数据结构实验之图论七:驴友计划
- 软件测试过程及其管理
- HDU 1284 钱币兑换问题(完全背包)
- Android 基于Gridview 实现日历选择,扩展性高,要自行扩展
- C++知识总结(6)
- codeforces 838D D. Airplane Arrangements 构造法 推公式
- 数据结构实验之图论七:驴友计划
- 机器学习算法常用指标总结
- java 写一个可以给斗地主玩家随机发牌的程序。
- Go 的并发 Concurrency
- ffmpeg通过rtsp获取H264裸流并保存到mp4文件
- 个人介绍
- java中bio,nio,aio详解
- 1.11 C# 静态类和单例
- 虚函数作用