如何快速有效的构建多重,是想要获得大量ap所需要考虑的。当然熟练如我已经可以随心所欲做多重了,跟那些xjbl玩家可不一样。

原文来自G+,据说是某复旦大佬写的


本文内容受这篇文章https://plus.google.com/104389566591650709184/posts/Bo9MXpwYw21的启发,并且其实是对其结论的一个扩展,感谢原作者+Kondo Joe

可在此参考最终结论和操作步骤: http://m.guokr.com/post/569758/

被凸n边形link包围的m个portal,最多且必然可连出(3m+n-2)个field

这句听起来有点拗口的话,实际上回答了一个问题:当地图上有乱七八糟一堆portal时

最多能从中连出多少个field?计算方法是:

1. 先将最外面一圈的点连起来,数一下有多少个顶点(n)

2. 数一下内部围住了多少个点(m) 

3. 代入公式计算:可连出(3*6+7-2)=23个field

 

以下是证明过程:

一个三角形内部有一个点时可以做4个field,这个相信大家已经很熟悉了吧

当三角形内有2个点时,可以任意选取一个点将大三角形分成3个小三角形,则剩下的一个点必然落在某个小三角形内,从而可以再用以上的方法分成3个三角形。

那么当三角形内有若干点的时候,可以反复用以上的方法划分,也就是说三角形内每有一个点,可以多做出3个field。

用这种方法可以保证连出最多的field,因为他实际是一个Appolonian Network (wiki),其特性之一就是拥有最多的内部三角形数。并且点的分布方式和选择顺序不会影响最终形成的三角形总数——这也很容易理解,因为点不管落在哪个三角形内,效果都是将其一分为三

但是ingress中要建立重复区域实际是有一些限制的,比如不能从field中间往外建link,并且建立link的先后顺序有一定要求,是不是对于任意分布的点一定能建成理论上限的field数呢?答案是肯定的,下面给出一种必然可行的策略:

1. 随便连一条大三角形的底边

2. 在三角形内部选一个点与底边连成三角形,使构成的三角形内没有其他点(一定做得到)

3. 以新连成的边为底边,在他们各自的小三角形内重复做以上事情

4. 全部做好以后应该是这样的

5. 然后从顶点到每个小三角形的顶点来一发(注意顺序)

实际情况下多数其实没这么复杂,只要稍微注意一下做link的顺序就行了。

以上讨论了三角形内部的情况,对于n边形来说,总是可以通过连接顶点将其分割为n-2个三角形

对于任意分布的点来说,这个多边形是唯一的,并且一定是凸多边形;分割的方法同样不影响最终形成的field数,因为多边形内部的任意点必然最终落在某一个三角形中。所以内部的点(m)能够做出的field数为3m,加上分割多边形形成的n-2个field,最终能够做出的field数为3m+n-2。

几个推论:

  1. 多边形内部的点每个价值为3个field,边上的点每个价值 为1个field
  2. n=3时就是三角形,是这个结论的一个特例,能够在portal数相同的情况下做出最多的field
  3. 完美连接的情况下,用掉的key数量为 多边形的边数+分割多边形的link数+内部点数*3=n+(n-3)+3m=3m+2n-3
  4. 当边数很少,内部点数很多的时候,field数与link数之比趋近于1,也就是每一把key几乎都能做出一个field

那么就请大家多多利用以上的结论,利用有限的portal刷出更多的ap吧


END


本文被阅读了:2,492次

作者头像
关于  Ailitonia

正因站在了巨人的肩膀上,才越发觉得自己渺小。不求成为巨人,但求与其同行。 把自己所见所闻,记录下来。

→查看所有由Ailitonia发布的文章