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 ...
随机推荐
- 新手安装使用codeblocks
很多第一次使用codeblocks的新手总会遇到很多的问题,首先作为一名新手应该下一个完整版的codeblocks,下载地址链接: http://pan.baidu.com/s/1dDxKeD7 密码 ...
- MySQL性能、监控与灾难恢复
原文:MySQL性能.监控与灾难恢复 监控方案: up.time http://www.uptimesoftware.com/ 收费 Cacti http:/ ...
- DWR入门实例(二)
DWR(Direct Web Remoting) DWR is a Java library that enables Java on the server and JavaScript in a b ...
- Activity生命周期解决(有图有真相)
Activity完整的生命周期: 启动Activity的周期历程: watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvcGVuZ2t2/font/5a6L5L2 ...
- Android虚拟机器学习总结Dalvik虚拟机创建进程和线程分析
Dalvik调用一个成员函数时,虚拟机,假设发现,该成员函数是一个JNI办法,然后,它会直接跳转到其地址来运行.也就是说.JNI方法是直接在本地操作系统上运行的.而不是由Dalvik虚拟机解释器运行. ...
- 蓝牙4.0BLE cc2540 cc2541 ios OAD课程(空中固件升级)[原版的,多图]
蓝牙4.0BLE cc2540 cc2541 ios OAD课程(件) 为阿莫单片机论坛 www.AmoMcu.com 原创.仅仅公布于csdn博客, 如需转载,请注明出处,谢谢! ...
- Nginx并发訪问优化
Nginx反向代理并发能力的强弱,直接影响到系统的稳定性.安装Nginx过程,默认配置并不涉及到过多的并发參数,作为产品执行,不得不考虑这些因素.Nginx作为产品执行,官方建议部署到Linux64位 ...
- uva10067 Playing with Wheels 【建图+最短路】
题目:option=com_onlinejudge&Itemid=8&page=show_problem&problem=1008">uva10067 Play ...
- InstallShield自定义安装界面
原文:InstallShield自定义安装界面 版权声明: 可以任意转载,转载时请务必以超链接形式标明文章原始出处和作者信息. 前言: 对于一些InstallShield用户或企业,对于安装包界面除了 ...
- Linux 编程学习笔记----动笔makefile档
Befroe Beginning. 在设置暑假的plan ,关于Linux的书籍如今在看的是ALP和Linux高级程序设计(杨宗德)第三版.在计划中的是Linux高级环境编程. 如今開始关于Linux ...