题目

描述

不知每日疲于在城市的水泥森林里奔波的你会不会有时也曾向往过乡村的生活。你会不会幻想过,在夏日一个静谧的午后,你沉睡于乡间路边的树荫里,一片叶子落在了你的肩上, 而你正做着一个悠长的梦,一个没有城市的梦。我们的问题,正围绕着这个梦境展开……

从 Azure 求学的城市到 Azure 家乡的村庄由若干条路径连接,为了简化起见,我们把这些路径抽象成一个 N 个节点的无向图,每个节点用一个[1,N]内的整数表示,其中城市在S节点,Azure 的故乡在T 节点。在某些节点对(x,y)之间会有双向道路连接,道路的长度为c。不过最近某些道路可能会在施工,Azure 想知道,假如某条道路被施工而不能通行的话, 他到故乡的最短路经的长度为多少(多次询问)。

N,M,Q≤200000N,M,Q\leq 200000N,M,Q≤200000

题目大意

给你一个带权无向图,有起点和终点。然后有许多询问,询问删除某两点之间的边后的最短路。


分析&正解

这题是在某个PPT里看到的,都不知道在哪里可以评测,所以干脆没有打。

看看这题,感觉好像是一个非常经典的题型,可是……想不出来。

有一个思路:建立最短路图。

这个思路还是容易想到的,建立最短路图之后,如果删去的边不在最短路图之内,那么最短路就不变!

我们发现有些点是没有意义的,所以把它们删去。

最后形成的这个最短路图有一些有趣的性质。

先说明一下,这个最短路图还是当成无向图(我们平常建立的最短路图都是有向图)。

发现这个最短路图中有边双,缩点,然后继续观察。

我们会发现缩点之后的图是一条链。

为什么?万一是一棵树呢?

如果是一棵树,

因为这个图有起点和终点,我们假设起点在根节点,那么终点在某个叶子节点中。

由于我们已经在前面删掉了无意义的点,就是不会到终点的点。

那么除了起点到终点的这一条链,其它的分支都是没有意义的,所以会被删去。

这个结论很重要。

显然,如果删去的边在某个边双中,最短路的长度也是不会变的。

现在我们只需要思考,如果删去的是桥边,那么如何计算。

对于这些删去桥边的情况离线计算:

建立一个小根堆堆,存一些边,对于每个边(u,v)(u,v)(u,v),存入的值为disSu+len(u,v)+disTvdisS_u+len(u,v)+disT_vdisSu​+len(u,v)+disTv​。

它代表了如果必须走这条边的最短路径。

然后一个一个扫边双,到了某个边双之后,就将所有从先前的边双连向它的边从堆中删去,然后将所有从它连向后面的边双的边加进来。

搞完之后,如果要删去这个边双和下一个边双之间的桥边,那么堆中的最小值就是答案。

为什么这么做?

先不考虑删除边,

如果边(u,v)(u,v)(u,v)不得不经过,为了使得路径长度最小,那么起点到uuu,vvv到终点,这两段的路径一定在最短路图之中。

当一个边双和下一个边双之间的桥断开的时候,我们不能走桥,不得不走其它的路径。

必须要经过某一条跨过中间的边。

所以,我们要将不跨过中间的边,也就是之前的边双连向这个边双的边删去,然后把新的边加进来。

时间复杂度是O((N+M+Q)lg⁡N)O((N+M+Q)\lg N)O((N+M+Q)lgN),很优秀。


总结

在见到某些类似于动态最短路题目的时候,我们可以想到建立最短路图。

然后注意最短路图在缩点之后会变成一条链(有起点和终点的情况下)。

最后就是想想如何在边双之间处理东西。

感觉上这道题还挺不错,可惜没有地方评测……

[violet6] 故乡的梦的更多相关文章

  1. 【BZOJ-2725】故乡的梦 Dijsktra + Tarjan + Dinic + BFS + 堆

    2725: [Violet 6]故乡的梦 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 502  Solved: 173[Submit][Status ...

  2. BZOJ 2725: [Violet 6]故乡的梦 最短路+线段树

    2725: [Violet 6]故乡的梦 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 678  Solved: 204[Submit][Status ...

  3. BZOJ2725 : [Violet 6]故乡的梦

    如果S==T,那么答案为0. 如果S与T不连通,那么答案为inf. 否则,S到T的最短路径上至少有一条边. 求出以S为源点的最短路图,是个DAG,随便抓一条S到T的最短路,记为P. 设dpS[x]表示 ...

  4. [原博客] BZOJ 2725 : [Violet 6]故乡的梦

    这个题在bzoj上好像是个权限题,想做的可以去Vani的博客下载测试数据.这里有题面. 简单叙述一下题意:给你一个n个点.m条边的带权无向图,S点和T点,询问Q次删一条给定的边的S-T最短路. 其中  ...

  5. BZOJ 2725 [Violet 6]故乡的梦 线段树+最短路树

    \(\color{#0066ff}{ 题目描述 }\) \(\color{#0066ff}{输入格式}\) \(\color{#0066ff}{输出格式}\) \(\color{#0066ff}{输入 ...

  6. BZOJ 2725: [Violet 6]故乡的梦

    求出最短路径树,对于一个询问(x,y) 若不在树上S->T的链上,则答案不变,若在链上,考虑用一条非树边替换这条边,这条非树边必须跨越x->y这条边,线段树维护区间最小值 #include ...

  7. bzoj violet系列 (2708~2725)

    cbh大爷说:写博客不能弃坑. orz cbh 那我就来更新博客了. violet这个系列的题好神啊……出题人好劲啊…… ……怎么最近都在理性愉悦啊…… 另外bzoj400题纪念~ 2708: [Vi ...

  8. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  9. BZOJ 5395--[Ynoi2016]谁的梦(STL&容斥)

    5395: [Ynoi2016]谁的梦 Time Limit: 80 Sec  Memory Limit: 128 MBSubmit: 22  Solved: 7[Submit][Status][Di ...

随机推荐

  1. Invalid bound statement (not found): com.my.demo.mapper.UserMapper.getAll

    网上的方法全试了,配置全对,很奇怪. 最后一查,竟然忘记把mapper保存为xml格式. 记录一下.

  2. Ubuntu 18.04.2 aliases 设置永久生效解决方案

    设置 临时 alias alias ll="ls -al" 缺点是下次登录时就不生效了 永久生效解决方案 进入到 etc 文件夹下 cd /etc/ 创建 bash_aliases ...

  3. [转]WinForm DataGridView 绑定泛型List(List<T>)/ArrayList不显示的原因和解决

    背景:无意间遇到了一个不大不小的问题,希望对一些遇到的人有所帮助! 一.问题 WinForm DataGridView 绑定泛型List (List<T>)/ArrayList不显示,UI ...

  4. mave打包spring项目成jar,启动报错:Offending resource: URL [

    文章目录 错误 解决 错误 Offending resource: URL [jar:file:/Users/leesin/intellij-idea-workspace/rabbitMq_Consu ...

  5. nginx分布式实例入门操作

    本文目的 前段时间学习WCF已经渐入佳境,完成了既定学习目标,转入分布式系统学习.本文技术路线是: 采用wcf实现分布式服务端和客户端,客户端部署于本地主机,nginx和WCF部署于虚拟机端(分别是三 ...

  6. function attributes, MDK

    The keyword format is either of the following: __attribute__((attribute1, attribute2, ...)) __attrib ...

  7. Java 中的 SPI 机制是什么鬼?高级 Java 必须掌握!

    作者:sigangjun blog.csdn.net/sigangjun/article/details/79071850 SPI的全名为:Service Provider Interface,大多数 ...

  8. MySQL安装配置及测试

    1. 安装包下载 点击下载地址:https://dev.mysql.com/downloads/installer/打开页面,滑到较底端,按如下选择下载: 会弹出一个注册登录页面,可以不用管,直接点击 ...

  9. iOS开发系列-NSDate

    NSDate API 获取当前时间 获取时间戳 创建间隔指定时间戳的Date // 获取昨天 NSTimeInterval time = 24 * 60 * 60; NSDate *date = [N ...

  10. vim 底行模式 操作命令

    1. 当前设置行号: set nonu    取消行号显示:                    2.   :set number 显示行号     (下次使用就没有了,要设置脚本 vim ~/ . ...