POJ 3790 最短路径问题(Dijkstra变形——最短路径双重最小权值)
题目链接:
http://acm.hdu.edu.cn/showproblem.php?pid=3790
(1<n<=1000, 0<m<100000, s != t)
1 2 5 6
2 3 4 5
1 3
0 0
#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变形——最短路径双重最小权值)的更多相关文章
- POJ 2253 Frogger(Dijkstra变形——最短路径最大权值)
题目链接: http://poj.org/problem?id=2253 Description Freddy Frog is sitting on a stone in the middle of ...
- POJ 1797 Heavy Transportation(Dijkstra变形——最长路径最小权值)
题目链接: http://poj.org/problem?id=1797 Background Hugo Heavy is happy. After the breakdown of the Carg ...
- POJ.1797 Heavy Transportation (Dijkstra变形)
POJ.1797 Heavy Transportation (Dijkstra变形) 题意分析 给出n个点,m条边的城市网络,其中 x y d 代表由x到y(或由y到x)的公路所能承受的最大重量为d, ...
- POJ 3565 Ants 【最小权值匹配应用】
传送门:http://poj.org/problem?id=3565 Ants Time Limit: 5000MS Memory Limit: 65536K Total Submissions: ...
- POJ 2195 Going Home 【二分图最小权值匹配】
传送门:http://poj.org/problem?id=2195 Going Home Time Limit: 1000MS Memory Limit: 65536K Total Submis ...
- 【POJ 2400】 Supervisor, Supervisee(KM求最小权匹配)
[POJ 2400] Supervisor, Supervisee(KM求最小权匹配) Supervisor, Supervisee Time Limit: 1000MS Memory Limit ...
- POJ 3255 Roadblocks (Dijkstra求最短路径的变形)(Dijkstra求次短路径)
Roadblocks Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 16425 Accepted: 5797 Descr ...
- NYOJ 1248 海岛争霸(Dijkstra变形——最短路径最大权值)
题目链接: http://acm.nyist.net/JudgeOnline/problem.php?pid=1248 描述 神秘的海洋,惊险的探险之路,打捞海底宝藏,激烈的海战,海盗劫富等等.加勒比 ...
- POJ - 2253 Frogger(Dijkstra变形题)
题意: 题目撰写者的英语真是艰难晦涩,看了别人题解,才知道这题题意. 两个forger 一个froger 要蹦到另外一个froger处,他们的最短距离是这样定义的 : The frog distanc ...
随机推荐
- LAMP第四部分mysql操作
1. 忘记root密码编辑mysql主配置文件 my.cnf 在[mysqld]字段下添加参数 skip-grant ,重启数据库服务,这样就可以进入数据库不用授权了 mysql -uroot , ...
- Java ArrayIndexOutOfBoundsException: Exception Hierarchy
- Hello TensorFlow
官方说明:https://www.tensorflow.org/install/ 环境: 操作系统 :Windows 10 家庭中文版 处理器 : Intel(R) Core(TM) i7-7700 ...
- input选择框样式修改与自定义
html自带的选择框样式不好看,并且在ios设备上丑的罚款.所以一般都是自定义样式: 原理:将原来默认的input选择框隐藏,然后控制label的:before与:after,配合矢量图标或者图片来实 ...
- .bashrc:16: command not found: shopt配置环境变量时出错
source .bashrc ------------------------------------------------------- .bashrc:: command not found: ...
- 使用XML序列化实现系统配置 - 开源研究系列文章
在实际的C#软件系统开发过程中,会遇到系统配置的保存问题,以及系统存储问题.在以前的系统开发过程中,笔者使用的是INI文件配置管理的方式.到了现在,INI文件配置保存仍然是一个平常使用的方式.在博客园 ...
- 每天学一点Docker(4)-深入了解容器概念
什么是容器? 容器是一个自包含,可移植,轻量级的软件打包技术.是应用程序在任何地方几乎以相同方式运行.开发人员在开发机上创建好容器,无需任何修改就能在虚拟机,云服务器或公有云主机上运行. 容器与虚拟机 ...
- python词云的制作方法
第一次接触到词云主要是觉得很好看,就研究了一下,官方给出了代码的,但是新手看的话还是有点不容易,我们来尝试下吧. 环境:python2.7 python库:PIL(pillow),numpy,matp ...
- 浏览器根对象window之screen
1. screen 1.1 availHeight/Width screen.availWidth返回浏览器窗口可占用的水平宽度(单位:像素). screen.availHeight返回浏览器窗口在屏 ...
- 通过ArcMap发布服务
打开ArcMap,添加一个空地图 单击添加数据按钮 单击之后出现下图 点击 (连接到文件夹)按钮选择要添加的文件.添加之后如下. 保存为mxd文件 点击保存按钮就可以保存为mxd格式文件. 选择 Fi ...