【原题】

星系调查
【问题描写叙述】
银河历59451年。在银河系有许很多多已被人类殖民的星系。如果想要在行
星系间往来,大家一般使用连接两个行星系的跳跃星门。  一个跳跃星门能够把
物质在它所连接的两个行星系中互相传送。
露露、花花和萱萱被银河系星际联盟调查局任命调查商业巨擘ZeusLeague+
的不正当商业行为。
在银河系有N个已被ZeusLeague+成功打入市场的行星系,最好还是标号为
1,2,...,N。而ZeusLeague+在这N个行星系之间还拥有自己的M个跳跃星门。

使
用这些跳跃星门,ZeusLeague+的物资就能够在这N个行星系中两两随意互相传
输。

因为经费问题。跳跃星门的个数不会超过行星系的个数。
露露在颇费周折之后得到了ZeusLeague+在这N个行星系中的各自的贸易总
额C[i]。

萱萱设计了一个经济学特征指标D[i]来度量这N个行星系的经济学特征。于
是。我们能够用二元组(C[i],D[i])来表示第i个行星系的XP(Xuan's Position)。现
在如果我们有k个行星系的XPs,把它们放置在二维平面上,然后我们用一条直
线去拟合这些XPs。定义一条直线与XPs的相斥度为这条直线到各个XP的Euclid
距离的平方之和。再令XPs的线性如果相斥度为全部直线与XPs的相斥度中的
最小者。

那么。这个值越小,ZeusLeague+在这k个行星系中的相互贸易活动就
越可疑,从而值得进一步调查。花花负责计算很多行星系对(u,v)的非可疑度。一
条跳跃星门航线的非可疑度被定义为它经过的全部行星系(包含起点和终点)的
XPs的线性如果相斥度。

而一个行星系对(u,v)的非可疑度则被定义为全部以u为
起点,v为终点的跳跃星门航线的非可疑度中的最小值。一条跳跃星门航线是指
从某个行星系開始。通过跳跃星门依次到达某些行星系,然后终止。而且中途不
反复经过行星系,这种一个过程。

花花负责计算很多行星系对(u,v)的非可疑度。

一条跳跃星门航线的非可疑度
被定义为它经过的全部行星系(包含起点和终点)的XPs的线性如果相斥度。

而一个行星系对(u,v)的非可疑度则被定义为全部以u为起点,v为终点的跳跃星
门航线的非可疑度中的最小值。一条跳跃星门航线是指从某个行星系開始,通过
跳跃星门依次到达某些行星系,然后终止。而且中途不反复经过行星系,这种
一个过程。

在花花数天夜以继日的工作之后。平行调查组的你——大名鼎鼎的计算机科
学家Hcceleration.Gerk.Gounce不忍心看到她这样不眠不休,于是你在完毕了手
头的工作之后决定帮一帮她。
【输入格式】 
输入文件inv.in 的第一行是N,M,分别表示这个银河系内的行星系的个数
以及跳跃星门的个数。

接下来N行,每行2个正整数C[i], D[i]。表示第i 个行星系的XP(Xuan's 
Position)。

接下来的M行来描写叙述跳跃星门,每行2个正整数u[i],v[i],表示有一个连接
着行星系u[i]和v[i]的跳跃星门。注意这个连接是无向的。不会存在自己连向自
己的情况。也不会存在反复连接的情况。

接下来的一行。有一个正整数Q,表示花花须要计算的非可疑度的行星对数。
接下来的Q行,每行2个正整数s[i], t[i],表示花花须要计算从s[i]到t[i]的
非可疑度。

【输出格式】 
输出文件inv.out总共Q行,每一行一个实数。表示花花第i次须要计算的答
案。你的答案须要和标准答案的差不超过0.01才干得分。
【例子输入】 
6 6 
3 4 
5 6 
1 3 
4 4 
3 3 
2 4 
1 2 
1 3 
2 3 
2 4 
3 5 
5 6 

3 6 
2 4 
4 6 
【例子输出】 
0.66667 
0.00000 
1.67544
【数据规模与约定】 
提示:我们把行星系抽象成一个点,跳跃星门抽象成一条边。那么题目要描
述的是一张边数不会超过点数的联通无向图。

【分析】先直接列出了一个非常傻X的方程:

(图破了,就将就着看以下的第一个式子吧)

然后就不知道应该怎么办了,暴力展开?没什么用。

显然询问Q不是吃素的。每次必须转化为LGN的算法。

看了网上一篇大牛的题解,当时整个人都不好了——就是暴力 展开。

以下是细节。

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvamlhbmdzaGliaWFv/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/Center" alt="" />

太神了!推是非常好推,我真正动容的是:那么多项居然没有推错?!

瞬间就会了。我们维护从根节点到某一个点的上述全部值的和。

(能够开一个结构体,重载+。这样会方便非常多)

先不考虑环的情况。若计算x到y的路径。设z=LCA(x,y),那么我们用x、y、z带出全部项。

然后就是O(1)算出δ的值了。

如果有环。先用并查集或克鲁斯卡尔或dfs或bfs求出多出的那条边的左右两点。

我们仅仅需分类讨论环的左右点和x、y的关系。用相同的方法求解。

话说我在最后一步的时候还推错了,囧。

代码丑,就不放了。

bzoj 3528 [ZJOI2014] 星系调查 题解的更多相关文章

  1. bzoj 3528: [Zjoi2014]星系调查

    Description 银河历59451年,在银河系有许许多多已被人类殖民的星系.如果想要在行 星系间往来,大家一般使用连接两个行星系的跳跃星门.  一个跳跃星门可以把 物质在它所连接的两个行星系中互 ...

  2. bzoj 3528 [Zjoi2014]星系调查【树链剖分+数学】

    参考:https://www.cnblogs.com/zhuohan123/p/3698852.html 首先,根据点到直线距离公式 \[ d=\frac{kx_0-y_0+b}{\sqrt{k^{2 ...

  3. 题解 洛谷 P3340 【[ZJOI2014]星系调查】

    根据题意,发现题目中的图,其实就是一颗树或者是一颗基环树,每个节点上有一个点对\((x,y)\),每次询问为给定端点,找一条直线到端点间的所有点的距离之和最小. 设这条直线为\(y=kx+b\),根据 ...

  4. BZOJ3528: [Zjoi2014]星系调查

    唉,看到这题直接想起自己的Day1,还是挺难受的,挺傻一题考试的时候怎么就没弄出来呢…… 这两天CP让我给他写个题解,弄了不是很久就把这个题给弄出来了,真不知道考试的时候在干嘛. 明天就出发去北京了, ...

  5. bzoj 3519: [Zjoi2014] 消棋子 题解

    [序言]在大家怀疑的眼光下,我做了一个中午和半个下午.调了一个晚上的题目总算A了! [原题] 消棋子是一个有趣的游戏.游戏在一个r * c的棋盘上进行.棋盘的每一个格 子.要么是空,要么是一种颜色的棋 ...

  6. 「ZJOI2014」星系调查

    「ZJOI2014」星系调查 本题核心在于快速求XPs 的线性假设相斥度. 点\((x1,y1)\)到直线\(y=kx+b\)的距离的平方为\(\displaystyle {(kx1+b-y1)^2} ...

  7. BZOJ 4033: [HAOI2015]树上染色题解

    BZOJ 4033: [HAOI2015]树上染色题解(树形dp) 标签:题解 阅读体验:https://zybuluo.com/Junlier/note/1327400 原题地址: BZOJ 403 ...

  8. BZOJ 2768: [JLOI2010]冠军调查 最小割

    2768: [JLOI2010]冠军调查 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=2768 Description 一年一度的欧洲足 ...

  9. 【bzoj 3786】星系探索

    Description 物理学家小C的研究正遇到某个瓶颈. 他正在研究的是一个星系,这个星系中有n个星球,其中有一个主星球(方便起见我们默认其为1号星球),其余的所有星球均有且仅有一个依赖星球.主星球 ...

随机推荐

  1. input不记录之前输入的值

    autocomplete="off" // input中添加这个属性

  2. loj#101. 最大流 dinic+当前弧

    板子题 当前弧优化版本 目前效率最高 //#pragma comment(linker, "/stack:200000000") //#pragma GCC optimize(&q ...

  3. 绝对干货!!css3字体图标—丰富的阿里图标库iconfont的使用详解

    在移动端Web项目开发中,我们往往需要用到一些小图标,比如搜索,返回,小菜单,小箭头等等..这如果还用切图你就OUT了.. 而这时CSS3提供的字体图标无疑是我们最好的选择,它就像字体一样,可以设置大 ...

  4. 附录A——面向对象基础

    在学习设计模式之前,C#语言中一些基本的面向对象的知识还是应该具备的,比如像继承.多态,接口.抽象类,集合.泛型等. A.2 类与实例 什么是对象? 一切事物(事和物)都是对象,对象就是可以看到.感觉 ...

  5. iOS UI-标签控制器(UITabBarController)

    #import "AppDelegate.h" #import "FirstViewController.h" #import "SecondView ...

  6. 快照库MV不能成功刷新问题的解决

    前几天,一个用户找到我,说他们的物化视图不能刷新了,这得从几天前主库的一次意外down机说起(另文说明),前几天,用户现场的一个中心库因某原因意外down掉了,当时短期内对中心库进行了重启修复,没有造 ...

  7. learning scala read from console

    控制台输入语句: readInt, readDouble, readByte, readShort, readLong, readChar, readBoolean, readLine example ...

  8. MongoDB中_id(ObjectId)生成

    MongoDB 中我们经常会接触到一个自动生成的字段:"_id",类型为ObjectId. 之前我们使用MySQL等关系型数据库时,主键都是设置成自增的.但在分布式环境下,这种方法 ...

  9. hdu 2874 Connections between cities(st&rmq LCA)

    Connections between cities Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 32768/32768 K (J ...

  10. 静态函数和全局函数都没有this指针

    静态函数和全局函数都没有this指针