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 ...
随机推荐
- JQuery攻略(五)表单验证
表单验证,字段空白,输入合法,数据合法....... 此章节有 1.1字段验证 1.2正则表达式验证 1.3复选框的勾选 1.1字段验证 1.字段非空 $(document).ready(functi ...
- 用开源项目ExpandableTextView打造可以下拉扩展的TextView
这次还是用开源项目来实现效果,我个人觉得上面的这个效果还是很赞的.于是就记录下如何实现这个效果,其实相当简单.这就是开源项目写的好的例子,整个开源项目的代码十分清晰,逻辑和代码结构都很棒,接入自己的工 ...
- Statistical Artifact (error)
In natural science and signal processing, an artifact is any error in the perception or representati ...
- 对CAP定理的理解
CAP定理的常规解释是任何分布式系统只能在一致性(Consitency),可用性(Availability)和分区容忍性(Partition Tolerance)中三选二.这个解释很让人费解,笔者在看 ...
- django时区设置以及全球用户如何各自显示当地时间
在Django的配置文件settings.py中,有两个配置参数是跟时间与时区有关的,分别是TIME_ZONE和USE_TZ 如果USE_TZ设置为True时,Django会使用系统默认设置的时区,即 ...
- 从零开始学C++之模板(三):缺省模板参数(借助标准模板容器实现Stack模板)、成员模板、关键字typename
一.缺省模板参数 回顾前面的文章,都是自己管理stack的内存,无论是链栈还是数组栈,能否借助标准模板容器管理呢?答案是肯定的,只需要多传一个模板参数即可,而且模板参数还可以是缺省的,如下: temp ...
- go语言之进阶篇无缓冲channel
1.无缓冲channel 示例: package main import ( "fmt" "time" ) func main() { //创建一个无缓存的ch ...
- [leetcode]Unique Binary Search Trees II @ Python
原题地址:https://oj.leetcode.com/problems/unique-binary-search-trees-ii/ 题意:接上一题,这题要求返回的是所有符合条件的二叉查找树,而上 ...
- [Python爬虫] :Selenium +phantomjs 利用 pyquery抓取脚本链接对应的内容
抓取上面对应链接的网页的文章的内容 ele = element.attr("onclick") self.driver.execute_script(ele) sub_seleni ...
- (转载)Java8新的日期API LocalDate, LocalTime
前言 由于Java Date的各种问题,Java8推出了新的日期API,很受一拨人的追捧. 为什么我们需要新的Java日期/时间API? 在开始研究Java 8日期/时间API之前,让我们先来看一下为 ...