HDU 1385 Minimum Transport Cost 最短路径题解
本题就是使用Floyd算法求全部路径的最短路径,并且须要保存路径,并且更进一步须要依照字典顺序输出结果。
还是有一定难度的。
Floyd有一种非常巧妙的记录数据的方法,大多都是使用这种方法记录数据的。
只是事实上本题数据不是非常大,一般太大的数据也无法使用Floyd,由于效率是O(N^3)。
所以事实上也能够使用一般的Floyd算法,然后添加个三维数组记录数据。以下就是这样的做法,0ms过了.
#include <stdio.h>
#include <vector>
using std::vector; vector<int> checkDictOrder(vector<int> a, vector<int> b)
{
for (int i = 0; i < (int)a.size() && i < (int)b.size(); i++)
{
if (a[i] < b[i]) return a;
else if (a[i] > b[i]) return b;
}
return a.size() < b.size() ? a : b;
} void FloydWarshall(vector<vector<int> > &gra, vector<int> &tax,
vector<vector<vector<int> > > &paths)
{
int N = (int)gra.size(); for (int i = 0; i < N; i++)
{
for (int j = 0; j < N; j++)
{
if (-1 != gra[i][j])
{
paths[i][j].push_back(i);
paths[i][j].push_back(j);
}
}
} for (int k = 0; k < N; k++)
{
for (int i = 0; i < N; i++)
{
for (int j = 0; j < N; j++)
{
if ( -1 != gra[i][k] && -1 != gra[k][j] &&
(-1 == gra[i][j] ||
gra[i][k] + gra[k][j] + tax[k] <= gra[i][j]))
{
vector<int> t = paths[i][k];
t.pop_back();//pop k out
t.insert(t.end(), paths[k][j].begin(), paths[k][j].end());
if (gra[i][k]+gra[k][j]+tax[k]==gra[i][j])
paths[i][j] = checkDictOrder(t, paths[i][j]);
else paths[i][j] = t; gra[i][j] = gra[i][k] + gra[k][j] + tax[k];
}
}
}
}
} int main()
{
int N, g, h;
while (scanf("%d", &N) && N)
{
vector<vector<int> > gra(N, vector<int>(N));
for (int i = 0; i < N; i++)
{
for (int j = 0; j < N; j++)
{
scanf("%d", &gra[i][j]);
}
}
vector<int> tax(N);
for (int i = 0; i < N; i++)
{
scanf("%d", &tax[i]);
} vector<vector<vector<int> > > paths(N, vector<vector<int> >(N));
FloydWarshall(gra, tax, paths);
while (scanf("%d %d", &g, &h) && g != -1 && h != -1)
{
printf("From %d to %d :\nPath: ", g, h);
g--, h--;
if(g != h)
{
for (int u = 0; u+1 < (int)paths[g][h].size(); u++)
{
printf("%d-->", paths[g][h][u]+1);
}
}
printf("%d\nTotal cost : %d\n\n", h+1, gra[g][h]);
}
}
return 0;
}
HDU 1385 Minimum Transport Cost 最短路径题解的更多相关文章
- HDU 1385 Minimum Transport Cost (Dijstra 最短路)
Minimum Transport Cost http://acm.hdu.edu.cn/showproblem.php?pid=1385 Problem Description These are ...
- hdu 1385 Minimum Transport Cost(floyd && 记录路径)
Minimum Transport Cost Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/O ...
- hdu 1385 Minimum Transport Cost (Floyd)
Minimum Transport CostTime Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Ot ...
- hdu 1385 Minimum Transport Cost (floyd算法)
貌似···················· 这个算法深的东西还是很不熟悉!继续学习!!!! ++++++++++++++++++++++++++++ ======================== ...
- hdu 1385 Minimum Transport Cost
http://acm.hdu.edu.cn/showproblem.php?pid=1385 #include <cstdio> #include <cstring> #inc ...
- HDU 1385 Minimum Transport Cost (最短路,并输出路径)
题意:给你n个城市,一些城市之间会有一些道路,有边权.并且每个城市都会有一些费用. 然后你一些起点和终点,问你从起点到终点最少需要多少路途. 除了起点和终点,最短路的图中的每个城市的费用都要加上. 思 ...
- HDU 1385 Minimum Transport Cost (输出字典序最小路径)【最短路】
<题目链接> 题目大意:给你一张图,有n个点,每个点都有需要缴的税,两个直接相连点之间的道路也有需要花费的费用.现在进行多次询问,给定起点和终点,输出给定起点和终点之间最少花费是多少,并且 ...
- HDU 1385 Minimum Transport Cost( Floyd + 记录路径 )
链接:传送门 题意:有 n 个城市,从城市 i 到城市 j 需要话费 Aij ,当穿越城市 i 的时候还需要话费额外的 Bi ( 起点终点两个城市不算穿越 ),给出 n × n 大小的城市关系图,-1 ...
- 【HDOJ】1385 Minimum Transport Cost
Floyd.注意字典序!!! #include <stdio.h> #include <string.h> #define MAXNUM 55 #define INF 0x1f ...
随机推荐
- ICT工作的思考<两>
2周奋战.我负责的LB昨天完成了最后一个模块.最后20日. 一周早于预期,经理说,出乎他的意料.So 奖励表,昨日,管理人员与我们合作,吃烧烤补补身子.我只想说,最后一个喘息. 这两周的生活确挺忙碌的 ...
- 使用jQuery和css3实现了仿淘宝ued博客左边的菜单切换动画
今天看到淘宝ued博客的左侧导航菜单的动画好,要使用jQuery和css3我做一个简单的示例,主要用途是实现jQuery 事件和css3 transition属性. 个元素来实现鼠标滑动到某个导航的背 ...
- 探秘Java虚拟机——内存管理与垃圾回收(转)
本文主要是基于Sun JDK 1.6 Garbage Collector(作者:毕玄)的整理与总结,原文请读者在网上搜索. 1.Java虚拟机运行时的数据区 2.常用的内存区域调节参数 -Xms:初始 ...
- 具体说明 Flume介绍、安装和配置
社论: 本文总结"Hadoop生态系统"中的当中一员--Apache Flume 写在前面二: 所用软件说明: 一.什么是Apache Flume 官网:Flume is a di ...
- java安全性语言
java通过所谓的沙箱安全模型保证了其安全性,以下我们就来看看java提供的安全沙箱机制. 组成沙箱的基本组件例如以下: 1.类装载器结构: 2.class文件检验器: 3.内置于java虚拟机(及语 ...
- C++ Primer 学习笔记_41_STL实践与分析(15)--先来看看算法【下一个】
STL实践与分析 --初窥算法[下] 一.写容器元素的算法 一些算法写入元素值.在使用这些算法写元素时一定要当心.必须.写入输入序列的元素 写入到输入序列的算法本质上是安全的--仅仅会写入与指定输入范 ...
- Think in Java(一):Java基础
一. OOP的特点 (1) 万物皆为对象; (2) 程序是对象的集合,他们通过发送信息来告诉彼此所要做的; (3) 每一个对象都有自己的由其它对象所构成的存储; (4) 每一个对象都拥有它的类型; ( ...
- iOS UITableViewCell AccessoryType属性
写了这么长时间的ios table 竟然不知道有一个Accessory来显示详情设置小图标,曾经竟然傻帽的取用一张图片来显示,如今想想真是..那痛啊.... cell.accessoryType = ...
- UVA662- Fast Food
题意:在一条公路上,有n个酒店,要建造k个供给站(建造在酒店所在的位置),给出酒店的位置,求怎么样建造供给站才干使得每一个酒店都能得到服务且所要走的路程最短. 思路:在i到j酒店建立一个供给站,要使得 ...
- High Performance Browser Networking - TCP UDP TLS
延迟 定义和标准延迟 延迟简单地说,它是一种转移或信息包从起点到终点,所花费的时间. 延迟=发送延迟+传播延迟+处理延迟+排队延迟: Propagation delay 传播时延 传播时延这个概念.是 ...