题目大意:给出出发点和终点和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(负环)的更多相关文章

  1. POJ 3259 Wormholes (判负环)

    Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 46123 Accepted: 17033 Descripti ...

  2. ACM: POJ 3259 Wormholes - SPFA负环判定

     POJ 3259 Wormholes Time Limit:2000MS     Memory Limit:65536KB     64bit IO Format:%lld & %llu   ...

  3. uva 558 - Wormholes(Bellman Ford判断负环)

    题目链接:558 - Wormholes 题目大意:给出n和m,表示有n个点,然后给出m条边,然后判断给出的有向图中是否存在负环. 解题思路:利用Bellman Ford算法,若进行第n次松弛时,还能 ...

  4. POJ 3259 Wormholes(最短路,判断有没有负环回路)

    Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 24249   Accepted: 8652 Descri ...

  5. Poj 3259 Wormholes(spfa判负环)

    Wormholes Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 42366 Accepted: 15560 传送门 Descr ...

  6. poj 3259 Wormholes【spfa判断负环】

    Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 36729   Accepted: 13444 Descr ...

  7. POJ 3259 Wormholes( bellmanFord判负环)

    Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 36425   Accepted: 13320 Descr ...

  8. (简单) POJ 3259 Wormholes,SPFA判断负环。

    Description While exploring his many farms, Farmer John has discovered a number of amazing wormholes ...

  9. POJ 1151 Wormholes spfa+反向建边+负环判断+链式前向星

    Wormholes Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 49962   Accepted: 18421 Descr ...

随机推荐

  1. HttpMessageNotWritableException: Could not write JSON: No serializer found for class ****

    今天碰到一个异常,下面是错误信息 org.springframework.http.converter.HttpMessageNotWritableException: Could not write ...

  2. [Linux] ubuntu各目录含义

    /boot/: 启动文件,所有与系统启动有关的文件都保存在这里 /boot/grub/:grub引导器相关的配置文件都在这里 /dev/:此目录中保存了所有设备文件,例如,使用的分区:/dev/hda ...

  3. 数据库实例: STOREBOOK > 用户 > 编辑 用户: SYSMAN

    ylbtech-Oracle:数据库实例: STOREBOOK  >  用户  >  编辑 用户: SYSMAN 编辑 用户: SYSMAN 1. 一般信息返回顶部 1.1,   1.2, ...

  4. javascript对象constructor属性

    概述 返回一个指向创建了该对象原型的函数引用.需要注意的是,该属性的值是那个函数本身,而不是一个包含函数名称的字符串.对于原始值(如1,true 或 "test"),该属性为只读. ...

  5. C#操作json类型数据

    将对象序列化为 JavaScript 对象表示法 (JSON),并将 JSON 数据反序列化为对象. 此类不能继承. // msdn 例子: namespace SL_DataContractJson ...

  6. svg image标签降级技术

    1.svg image标签降级技术: svg不能很好的在anroid2.3中得到支持,需要额外的补充,IE8-以及Android 2.3默认浏览器是不支持SVG的. svg image标签降级技术,这 ...

  7. CSS阻塞渲染、怎么防止css阻塞

    浏览器渲染流程: 1.浏览器开始解析目标HTML文件,执行流的顺序为自上而下. 2.HTML解析器将HTML结构转换为基础的DOM(文档对象模型),构建DOM树完成后,触发DomContendLoad ...

  8. 命令行打印文件树列表: tree

    Linux & Mac 1.下载tree lib //mac brew install tree //centos yum install tree //ubuntu apt-get inst ...

  9. [置顶] Hadoop2.2.0中HDFS的高可用性实现原理

    在Hadoop2.0.0之前,NameNode(NN)在HDFS集群中存在单点故障(single point of failure),每一个集群中存在一个NameNode,如果NN所在的机器出现了故障 ...

  10. chrome中打开 swf下载的问题

    https://helpx.adobe.com/cn/flash-player/kb/enabling-flash-player-chrome.html 1. 在地址栏中,键入 chrome://se ...