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 ...
随机推荐
- 【Java基础】System.arraycopy()的使用详解
由于在Java中System.arraycopy()方法在一维数组和二维数组中的表现不同,所以做了一个测试 public static void main(String[] args) { int[] ...
- 算法导论学习---红黑树具体解释之插入(C语言实现)
前面我们学习二叉搜索树的时候发如今一些情况下其高度不是非常均匀,甚至有时候会退化成一条长链,所以我们引用一些"平衡"的二叉搜索树.红黑树就是一种"平衡"的二叉搜 ...
- HTML5中类jQuery选择器querySelector的高级使用 document.querySelectorAll.bind(document);
基本用法 querySelector 该方法返回满足条件的单个元素.按照深度优先和先序遍历的原则使用参数提供的CSS选择器在DOM进行查找,返回第一个满足条件的元素. ----> querySe ...
- RH253读书笔记(7)-Lab 7 Electronic Mail
Lab 7 Electronic Mail Goal: To build common skills with MTA configuration Estimated Duration: 90 min ...
- 学习笔记之TCP/IP协议的重要性
1. 随处可见的协议 在计算机网络与信息通信领域里,人们常常提及"协议"一词.互联网中常 用的具有代表性的协议有IP.TCP.HITP等. 而LAN(局域网)中经常使用的协 ...
- C++随机数的使用方法
学过别的高级语言的都知道,产生随机数用的都是相似于random这种字符,c++也不例外,在C++中使用的是rand()函数,可是不同的是,假设在C++中仅仅使用了比如 "int i ...
- Coco2d-x android win7 Python 游戏开发环境的搭建
1:我用的电脑配置 win7 3 核 内存8G 桌面.一直想学习Coco2d 游戏开发,所以,一个星期后,需要找到,最终建立了一个良好的环境 2:我使用的版本号版本号,至于建筑android开发环境略 ...
- twitter接口开发
前一阵子研究了下twitter接口,发现网上的资料不是很多.遂花了些心血,终于有所收获~ 现在有时间赶紧整理出来便于自己以后查阅,也想帮助有困难的同学们.废话不多说,现在就以最简洁的方式开始了.注意: ...
- Flex4 Alert PopupManager 演示样本
Flex4中间PopupManager分类似模仿桌面用户界面弹出窗体,有些人还喜欢JS弹出屏幕操作,底层接口灰色禁用掉. 创建需要要喷射形式的文件,码如下面: <?xml version=&qu ...
- Oracle按不同时间分组统计
Oracle按不同时间分组统计 Oracle按不同时间分组统计的sql 如下表table1: 日期(exportDate) 数量(amount) -------------- ----------- ...