UVALive - 4618 Wormholes(负环)
题目大意:给出出发点和终点和m个虫洞(虫洞的出发点。终点,生成时间和花费时间)。问从起点到终点花费的最小时间
解题思路:关键是有负环,所以直接跑最短路算法的话会TLE。所以负环要处理一下
可是这个负环又不是负环。由于负环到一定程度的话。就会消失。
比方。到达时间小于虫洞的生成时间,那么负环就消失了。也就是说,负环内的点满足的最优情况就是到达时间刚好等于生成时间
所以,先找出负环,接着推断一下这个负环内的能节省的最多时间。然后将全部点都减去那个时间,那么负环就消失了
详细看代码
#include <cstdio>
#include <cstring>
#include <cmath>
#include <algorithm>
using namespace std;
#define N 110
#define INF 0x3f3f3f3f
struct Point{
int x, y, z;
}s1, s2;
struct wormhole{
Point s, t;
int start, cost;
}W[N];
int n, source, sink;
int dis[N][N];
int distance(int i, int j) {
int x = W[i].t.x - W[j].s.x;
int y = W[i].t.y - W[j].s.y;
int z = W[i].t.z - W[j].s.z;
return ceil(sqrt(1.0 * x * x + 1.0 * y * y + 1.0 * z * z));
}
void init() {
scanf("%d%d%d%d%d%d%d", &s1.x, &s1.y, &s1.z, &s2.x, &s2.y, &s2.z, &n);
source = 0;
sink = n + 1;
W[0].s = s1;
W[0].t = s1;
W[0].start = -INF;
W[0].cost = 0;
W[sink].s = s2;
W[sink].t = s2;
W[sink].start =-INF;
W[sink].cost = 0;
for (int i = 1; i <= n; i++)
scanf("%d%d%d%d%d%d%d%d", &W[i].s.x, &W[i].s.y, &W[i].s.z, &W[i].t.x, &W[i].t.y, &W[i].t.z, &W[i].start, &W[i].cost);
//dis[i][j]表示从第i个虫洞的终点走到第j个虫洞的出发点的时间
for (int i = 0; i <= sink; i++)
for (int j = 0; j <= sink; j++)
dis[i][j] = distance(i, j);
}
int pre[N], d[N];
void solve() {
for (int i = 0; i <= sink; i++) {
d[i] = INF;
pre[i] = -1;
}
d[source] = 0;
while (1) {
int tmp;
bool flag = false;
//找最短路
for (int i = 0; i <= sink; i++)
for (int j = 0; j <= sink; j++) {
tmp = max(d[i] + dis[i][j], W[j].start) + W[j].cost;
if (tmp < d[j]) {
d[j] = tmp;
pre[j] = i;
flag = true;
}
}
//不用更新了
if (!flag) {
printf("%d\n", d[sink]);
return ;
}
for (int i = 0; i <= sink; i++) {
int k = i;
//推断有没有环
for (int j = 0; j <= sink && k != -1; j++) k = pre[k];
if (k == -1) continue;
//找出更新的值,破除这个负环,更新的值就是到达起点的值和生成时间的差的最小值。由于在负环内能够等待到生成时间
int Min = d[pre[k]] + dis[pre[k]][k] - W[k].start;
for (int j = pre[k]; j != k; j = pre[j])
Min = min(d[pre[j]] + dis[pre[j]][j] - W[j].start, Min);
//假设不存在负环了
if (Min <= 0) continue;
//更新负环内的点的距离,破解负环
d[k] -= Min;
for (int j = pre[k]; j != k; j = pre[j])
d[j] -= Min;
}
}
}
int main() {
int test;
scanf("%d", &test);
while (test--) {
init();
solve();
}
return 0;
}
UVALive - 4618 Wormholes(负环)的更多相关文章
- POJ 3259 Wormholes (判负环)
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 46123 Accepted: 17033 Descripti ...
- ACM: POJ 3259 Wormholes - SPFA负环判定
POJ 3259 Wormholes Time Limit:2000MS Memory Limit:65536KB 64bit IO Format:%lld & %llu ...
- uva 558 - Wormholes(Bellman Ford判断负环)
题目链接:558 - Wormholes 题目大意:给出n和m,表示有n个点,然后给出m条边,然后判断给出的有向图中是否存在负环. 解题思路:利用Bellman Ford算法,若进行第n次松弛时,还能 ...
- POJ 3259 Wormholes(最短路,判断有没有负环回路)
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 24249 Accepted: 8652 Descri ...
- Poj 3259 Wormholes(spfa判负环)
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 42366 Accepted: 15560 传送门 Descr ...
- poj 3259 Wormholes【spfa判断负环】
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 36729 Accepted: 13444 Descr ...
- POJ 3259 Wormholes( bellmanFord判负环)
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 36425 Accepted: 13320 Descr ...
- (简单) POJ 3259 Wormholes,SPFA判断负环。
Description While exploring his many farms, Farmer John has discovered a number of amazing wormholes ...
- POJ 1151 Wormholes spfa+反向建边+负环判断+链式前向星
Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 49962 Accepted: 18421 Descr ...
随机推荐
- 解决eclipse中web项目出现Project facet Java version 1.8 is not supported.的问题
项目的jdk和tomcat的jdk版本不同,将eclipse-preference-server-runtime environments点击你要用的tomcat点击edit-jre选择和你项目对应的 ...
- [转]Linux系统下如何查看及修改文件读写权限
转自 :http://www.cnblogs.com/CgenJ/archive/2011/07/28/2119454.html 查看文件权限的语句: 在终端输入:ls -l xxx.xxx (xxx ...
- PHP工程师笔试题
PHP工程师笔试题 提示:请将答案写在另外一张空白纸上,并在30分钟内完成. PHP 请写出include.require.include_once.require_noce的区别. include是 ...
- UrlRewriter && IIS7
为了在动态网站获得更好的url体验,往往采用url重写技术. 比如:http://blog.xujif.com/?p=268 可以重写为 http://blog.xujif.com/archives/ ...
- QT国际化(中英转换)
转载:https://blog.csdn.net/u012528526/article/details/54707233 QT国际化(中英转换) 我们都知道在安卓中,想做国际化很简单,只需要建立对应的 ...
- go语言之进阶篇方法的重写
1.方法的重写 示例: //Person类型,实现了一个方法 func (tmp *Person) PrintInfo() { fmt.Printf("name=%s, sex=%c, ag ...
- SharePoint自定义程序页面部署 不用重启IIS
SharePoint的部署方式默认是部署WSP包,尤其是有多个前端的时候WSP包的部署显得非常方便和快捷,但是WSP的部署需要重启整个IIS服务会造成SharePoint站点一段时间不能访问.结合自己 ...
- PL/SQL Developer执行.sql文件的几种方法
1.复制SQL 第一种方法非常常见,也非常简单,先用文本编辑器打开.sql文件,然后把sql复制到PL/SQL Developer的SQL窗口或者命令窗口中运行就行了,本来我也是这么做的,但是我将SQ ...
- winrar5.50去广告教程(仅供学习使用)
https://blog.csdn.net/EnigmCode/article/details/78328873 第一步:到WinRAR官网www.rarlab.com下载自己需要的版本,我这里选择C ...
- Redis 在线管理工具(phpRedisAdmin)介绍
phpRedisAdmin is a simple web interface to manage Redis databases. phpRedisAdmin 在 Redis clients 的列表 ...