题目链接:

http://acm.hdu.edu.cn/showproblem.php?pid=3790

Problem Description
给你n个点,m条无向边,每条边都有长度d和花费p,给你起点s终点t,要求输出起点到终点的最短距离及其花费,如果最短距离有多条路线,则输出花费最少的。
 
Input
输入n,m,点的编号是1~n,然后是m行,每行4个数 a,b,d,p,表示a和b之间有一条边,且其长度为d,花费为p。最后一行是两个数 s,t;起点s,终点。n和m为0时输入结束。
(1<n<=1000, 0<m<100000, s != t)
 
Output
输出 一行有两个数, 最短距离及其花费。
 
Sample Input
3 2
1 2 5 6
2 3 4 5
1 3
0 0
 
Sample Output
9 11
 
Source
 题意描述:
输入顶点的个数n和道路的条数m以及起始点数s和t((1<n<=1000, 0<m<100000, s != t))
计算并输出最短距离及其花费(如果最短路径数相同,输出花费最小)
解题思路:
哇,读到这个题,心想求最短路径和最小花费,直接两边DijkstraOK,直接WA。
后来想想,先要保证路径最短,那么就先求最短路径,Dijkstra不变,只不过最后更新的时候处理一下最小花费就行了,具体处理方法见代码。
另外,既然存在路径相同而花费不同,那么必然输入数据存在两顶点相同,路径相同,但花费不同的数据,所以输入的时候我们只保留相同情况下花费最小即可。
题目很经典,如需了解
最长路径最小权值 请参考博客:http://www.cnblogs.com/wenzhixin/p/7336948.html
最短路径最大权值 请参考博客:http://www.cnblogs.com/wenzhixin/p/7406333.html
AC代码:
 #include<stdio.h>
int e1[][],e2[][];
int inf=,n,m,s,t;
void Dijkstra();
int main()
{
int i,j,t1,t2,t3,t4;
while(scanf("%d%d",&n,&m), n+m != )
{
for(i=;i<=n;i++)//全部初始化为inf
for(j=;j<=n;j++)
e1[i][j]=e2[i][j]=inf;//i和j for(i=;i<=m;i++)
{
scanf("%d%d%d%d",&t1,&t2,&t3,&t4);
if(e1[t1][t2] > t3)//存储的时候就去重,先保证路径最短,否则如
//果相等且花费变小则更新花费
{
e1[t1][t2]=e1[t2][t1]=t3;//双向
e2[t1][t2]=e2[t2][t1]=t4;
}
else if(e1[t1][t2] == t3 && e2[t1][t2] > t4)
e2[t1][t2]=e2[t2][t1]=t4;
}
scanf("%d%d",&s,&t); Dijkstra();
}
return ;
}
void Dijkstra()
{
int i,j,u,v,min,d[],c[],book[];
for(i=;i<=n;i++)
{
d[i]=e1[s][i];
c[i]=e2[s][i];
}
for(i=;i<=n;i++)
book[i]=;//初始化为0
book[s]=; for(i=;i<=n-;i++)
{
min=inf;
for(j=;j<=n;j++)
{//找到距离s点最近的尚未访问的点
if(!book[j] && d[j] < min)
{
min=d[j];
u=j;
}
}
book[u]=;
for(v=;v<=n;v++)//遍历每个顶点
{
if(!book[v] && e1[u][v] < inf)
{//加入点U后,更新每个顶点到s的距离为最近,便于下次查找
if(d[v] > d[u]+e1[u][v])
{//和之前的去重一样,在保证最短路径且花费减少时 才更新最小花费
d[v]=d[u]+e1[u][v];
c[v]=c[u]+e2[u][v];
}
else if(d[v] == d[u]+e1[u][v] && c[v] > c[u]+e2[u][v])
c[v] = c[u]+e2[u][v];
}
}
}
printf("%d %d\n",d[t],c[t]);
}

POJ 3790 最短路径问题(Dijkstra变形——最短路径双重最小权值)的更多相关文章

  1. POJ 2253 Frogger(Dijkstra变形——最短路径最大权值)

    题目链接: http://poj.org/problem?id=2253 Description Freddy Frog is sitting on a stone in the middle of ...

  2. POJ 1797 Heavy Transportation(Dijkstra变形——最长路径最小权值)

    题目链接: http://poj.org/problem?id=1797 Background Hugo Heavy is happy. After the breakdown of the Carg ...

  3. POJ.1797 Heavy Transportation (Dijkstra变形)

    POJ.1797 Heavy Transportation (Dijkstra变形) 题意分析 给出n个点,m条边的城市网络,其中 x y d 代表由x到y(或由y到x)的公路所能承受的最大重量为d, ...

  4. POJ 3565 Ants 【最小权值匹配应用】

    传送门:http://poj.org/problem?id=3565 Ants Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: ...

  5. POJ 2195 Going Home 【二分图最小权值匹配】

    传送门:http://poj.org/problem?id=2195 Going Home Time Limit: 1000MS   Memory Limit: 65536K Total Submis ...

  6. 【POJ 2400】 Supervisor, Supervisee(KM求最小权匹配)

    [POJ 2400] Supervisor, Supervisee(KM求最小权匹配) Supervisor, Supervisee Time Limit: 1000MS   Memory Limit ...

  7. POJ 3255 Roadblocks (Dijkstra求最短路径的变形)(Dijkstra求次短路径)

    Roadblocks Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 16425   Accepted: 5797 Descr ...

  8. NYOJ 1248 海岛争霸(Dijkstra变形——最短路径最大权值)

    题目链接: http://acm.nyist.net/JudgeOnline/problem.php?pid=1248 描述 神秘的海洋,惊险的探险之路,打捞海底宝藏,激烈的海战,海盗劫富等等.加勒比 ...

  9. POJ - 2253 Frogger(Dijkstra变形题)

    题意: 题目撰写者的英语真是艰难晦涩,看了别人题解,才知道这题题意. 两个forger 一个froger 要蹦到另外一个froger处,他们的最短距离是这样定义的 : The frog distanc ...

随机推荐

  1. Python学习_01_对象

    之前关于python的知识比较零散,这一个系列的随笔将python重新学习整理一遍.学习书籍<Python核心编程>第二版. Python对象基础 python并不是一个单纯面向对象的语言 ...

  2. 【AC自动机】Lougu P3796

    题目描述 有NNN个由小写字母组成的模式串以及一个文本串TTT.每个模式串可能会在文本串中出现多次.你需要找出哪些模式串在文本串TTT中出现的次数最多. 输入输出格式 输入格式: 输入含多组数据. 每 ...

  3. Java设计模式总汇二(小白也要飞)

    PS:上一篇我介绍了适配器设计模式.单例设计模式.静态代理设计模式.简单工厂设计模式,如果没有看过第一篇的小火鸡可以点这个看看http://www.cnblogs.com/cmusketeer/p/8 ...

  4. The `XXXX` target overrides the `HEADER_SEARCH_PATHS` build setting defined in `Pods/Target Support Files/Pods-game-desktop/Pods-game-desktop.release.xcconfig'. This can lead to prob

    The `game-desktop [Release]` target overrides the `HEADER_SEARCH_PATHS` build setting defined in `Po ...

  5. TextView 的新特性,Autosizing 到底是如何实现的? | 源码分析

    一.前言 Hi,大家好,我是承香墨影! 前两天聊了一下 Autosizing 的使用,反映还不错.毕竟是这种能解决实际问题的新 Api,确实在需要的时候,用起来会很顺手. 简单回顾一下,Autosiz ...

  6. 腾讯windows系统服务器

    今天用腾讯的服务器搭建起了自己的博客,先看主页效果...简单的ui设计,主要就是要上服务器看看.    说说服务器的搭建: 1.卖,进腾讯云,自己对应的买操作系统的就可以的啦.具体的链接: https ...

  7. 部署spring Boot项目到tomcat

    导火线 : 遇到两次本地可以跑通,部署到服务器tomcat就出问题的情况了,为了不忘记,记录在此吧 第一次部署到服务器上是静态资源访问不了,花了一些时间,是因为application.yml中的 mv ...

  8. 学Java必看,不看的人都后悔了

    什么是Java? Java是一门面向对象编程语言,不仅吸收了C++语言的各种优点,还摒弃了C++里难以理解的多继承.指针等概念,因此Java语言具有功能强大和简单易用两个特征.Java语言作为静态面向 ...

  9. 手把手教你用Vue造轮子(3):开发可排序的表格组件

    前言 最近闰土大叔跟Vue干上了,没办法,公司业务驱动,不用Vue没招啊,leader尝到了前后端分离带来的好处,除非你离职,哈哈哈,当然,那是不可能的,对于我这种要攒钱买房子的人来说.那还说什么呢, ...

  10. fiddler抓手机报文的配置指南

    前言 1.fiddler大名鼎鼎的抓包工具,而且支持重发,自动解码报文之类. 2.做爬虫时经常遇到需要抓移动端(手机/pad等)报文的情况. 网上各种资料比较,下面这篇是最准确的,转载自csdn:ht ...