zoukankan      html  css  js  c++  java
  • 「考试」小P的生成树

    考场上想到一半正解,没想到随机化,不然也许能够$A$掉。

    题目所说的其实就是向量加法,求模长最长的向量生成树。

    我们考虑对于两个向量,必然在平行边形对角线方向上,他们的投影和是最大的,长度就是对角线长度。

    如果精度开到$1e-3$我们完全可以枚举最终的和向量的角度,因为只有在对角线,也就是正确的方向上,向量的模长才是最大的,所以也就是说即使枚举的角度不可构成,它得出的解也必然不是最优解。

    但是精度开的很高,枚举复杂度过高了。(随机化角度就能A)

    接着考虑对于某条向量有两种表达形式:

    1.$(alpha,eta)$也就是坐标表示。

    2.$(varphi,iota)$其中$iota=sqrt{alpha^2+eta^2}$,也就是极角模长表示。

    向量在某个单位向量$( heta)$上的投影$len$就是:

    $$len=cos(varphi- heta)iota$$

    其中:

    $$cos{varphi}=frac{x}{iota},sin{varphi}=frac{y}{iota}$$

    $$egin{array}{rcl}\len &=& cos(varphi- heta)iota\ &=& (cos{varphi}cos{ heta}+sin{varphi}sin{ heta})iota\&=&(frac{x}{iota}cos{ heta}+frac{y}{iota}sin{ heta})iota\&=&cos{ heta}x+sin{ heta}yend{array}$$

    然后可以求出两个向量投影相等时候的角度。

    求出这个角度,发现它满足的条件是:

    $$x_1cos{ heta}+y_1sin{ heta}=x_2cos{ heta}+y_2sin{ heta}$$

    那么:

    $$ an{ heta}=frac{y_2-y_1}{x_1-x_2}$$

    $$ heta=arctan{frac{y_2-y_1}{x_1-x_2}}+(pi)$$

    然后我们知道克鲁斯卡尔的过程,只跟边的相对大小有关系,那么其实只需要枚举$m^2$个角度即可,在这些角度中间不会发生生成树边决策改变,那么这些角度就足够了。

    最终复杂度$O(m^2logm)$

  • 相关阅读:
    《图解算法》读书笔记(十)K最近邻算法
    《图解算法》读书笔记(九) 动态规划
    《图解算法》读书笔记(八) 贪婪算法
    Go 常用包之fmt、flag包(四)
    GO环境及初始化项目(二)
    nginx fpm 常见错误对比分析
    Ueditor富文本添加、编辑视频,视频不显示解决方案
    phpunit 测试
    mysql 主从并行复制(MTS)
    Explain执行计划详解
  • 原文地址:https://www.cnblogs.com/Lrefrain/p/11702731.html
Copyright © 2011-2022 走看看