HDU(3790),最短路二级标准
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3790
最短路径问题
Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)
Total Submission(s): 22854 Accepted Submission(s):
6813
a,b,d,p,表示a和b之间有一条边,且其长度为d,花费为p。最后一行是两个数
s,t;起点s,终点。n和m为0时输入结束。
(1<n<=1000, 0<m<100000, s != t)
1 2 5 6
2 3 4 5
1 3
0 0
- #include <cstring>
- #include <stdio.h>
- #include <algorithm>
- using namespace std;
- #define maxn 1010
- #define INF 0x3f3f3f3f
- int dis[maxn],visit[maxn],cost[maxn];
- int maps[maxn][maxn],maps2[maxn][maxn];
- int n,m;
- int start,send;
- void dijkstra(int s)
- {
- for(int i=; i<=n; i++)
- {
- dis[i]=maps[start][i];
- cost[i]=maps2[start][i];
- visit[i]=;
- }
- visit[s]=;
- dis[s] = ;
- cost[s] = ;
- for(int i=; i<n-; i++)
- {
- int temp=INF, k =;
- for(int j=; j<=n; j++)
- {
- if(visit[j]==false)
- {
- if(temp>dis[j])
- {
- temp = dis[j];
- k = j;
- }
- }
- }
- visit[k]=;
- for(int j=; j<=n; j++)
- {
- if(!visit[j])
- {
- if(dis[j]>dis[k]+maps[k][j])
- {
- dis[j]=dis[k]+maps[k][j];
- cost[j]=cost[k]+maps2[k][j];
- }
- else if(dis[j]==dis[k]+maps[k][j])
- cost[j]=min(cost[j],cost[k]+maps2[k][j]);
- }
- }
- }
- }
- int main()
- {
- //freopen("input.txt","r",stdin);
- while(scanf("%d%d",&n,&m),n)
- {
- for(int i=; i<=n; ++i)
- {
- for(int j=; j<=n; ++j)
- {
- if(i==j)
- maps[i][j]=maps2[i][j]=;
- else
- maps[i][j]=maps2[i][j]=INF;
- }
- }
- while(m--)
- {
- int a,b,d,c;
- scanf("%d%d%d%d",&a,&b,&d,&c);
- if(maps[a][b]>d)
- {
- maps[a][b]=maps[b][a]=d;
- maps2[a][b]=maps2[b][a]=c;
- }
- if(maps[a][b]==d&&maps2[a][b]>c)
- maps2[a][b]=maps2[b][a]=c;
- }
- scanf("%d%d",&start,&send);
- dijkstra(start);
- printf("%d %d\n",dis[send],cost[send]);
- }
- return ;
- }
HDU(3790),最短路二级标准的更多相关文章
- ACM: HDU 3790 最短路径问题-Dijkstra算法
HDU 3790 最短路径问题 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Des ...
- ACM: HDU 2544 最短路-Dijkstra算法
HDU 2544最短路 Time Limit:1000MS Memory Limit:32768KB 64bit IO Format:%I64d & %I64u Descrip ...
- UESTC 30 &&HDU 2544最短路【Floyd求解裸题】
最短路 Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submiss ...
- hdu 5521 最短路
Meeting Time Limit: 12000/6000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total ...
- HDU - 3790 最短路径问题 (dijkstra算法)
HDU - 3790 最短路径问题 Description 给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费 ...
- HDU - 2544最短路 (dijkstra算法)
HDU - 2544最短路 Description 在每年的校赛里,所有进入决赛的同学都会获得一件很漂亮的t-shirt.但是每当我们的工作人员把上百件的衣服从商店运回到赛场的时候,却是非常累的!所以 ...
- HDU 3790最短路径问题 [最短路最小花费]
题目链接:[http://acm.hdu.edu.cn/showproblem.php?pid=3790] 最短路径问题 Time Limit: 2000/1000 MS (Java/Others) ...
- hdu 3790 最短路径问题(两个限制条件的最短路)
http://acm.hdu.edu.cn/showproblem.php?pid=3790 有两个条件:距离和花费.首先要求距离最短,距离相等的条件下花费最小. dijkstra,仅仅是在推断条件时 ...
- HDU 3790 最短路径问题 (最短路)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3790 简单的最短路问题,这题听说有重边.我用spfa和dijkstra写了一遍,没判重边,速度都差不多 ...
随机推荐
- G面经prepare: BuyGoods
给你一部分钱和一些不同价钱的商品,如何在最多买K件商品的情况下尽可能多的花掉手里的钱. 举例:口袋里的钱数: 10; K=2 产品价格: [3, 6, 8, 7, 9] 输出 3, 7 Backtra ...
- Smarty模板
Smarty模板 是做什么用的?? 是将前端的显示和后台的逻辑进行分离,就相当于把前台显示的页面和后台要实现的某些功能的逻辑给分离出来了,分离在两个文件里,也就是说,前端只负责显示,后端只负责逻辑操作 ...
- hdu 2528 Area
2014-07-30 http://acm.hdu.edu.cn/showproblem.php?pid=2528解题思路: 求多边形被一条直线分成两部分的面积分别是多少.因为题目给的直线一定能把多边 ...
- 安装Eclipse并配置JacORB插件
前人成果 • eclipse中开发corba完整说明(jacORB版) http://blog.csdn.net/hq0927/article/details/8129534 • ...
- oracle 的索引
一.索引分类 按逻辑分: 单列索引(Single column): 单列索引是基于单列所创建的索引 复合(多列)索引(Concatenated ): 复合索引是基于两列或者多列所创建的索引 ...
- PTPX中的activity文件以及mapping文件
在不同的simulation中的capturing switching activity: SAIF:Switching Activity Interface Format,包含toggle coun ...
- android SDK安装容易出错的原因
1.实际上,安卓SDK安装之后,拷贝到其他的机子上面.配置一下环境变量,就可以跑起来的 2.但是拷贝到其他的机子上面临着一个问题就是Eclipse已经配置了的android环境,需要在新的机子上面修改 ...
- tcp socket
1.TCP连接手机能够使用联网功能是因为手机底层实现了TCP/IP协议,可以使手机终端通过无线网络建立TCP连接.TCP协议可以对上层网络提供接口,使上层网络数据的传输建立在"无差别&quo ...
- JeeSite开发笔记
开发流程笔记: http://m.blog.csdn.net/article/details?id=51251619
- linux设备驱动归纳总结(三):1.字符型设备之设备申请【转】
本文转载自:http://blog.chinaunix.net/uid-25014876-id-59416.html linux设备驱动归纳总结(三):1.字符型设备之设备申请 操作系统:Ubunru ...