• 10.11 牛客


    10.11 牛客


    得分情况

    30 + 0 + 40 + 0 = 70


    题解

    T1 最终测试

    (30 Pts)

    枚举所有可能性 对于每种可能性 对选手排序得到排名


    (60 Pts)

    (E_i) 表示第 (i) 为选手的期望排名 (s_i) 为第 (i) 位选手的得分 有:

    [E_i = 1 + sum_{j e i}P(s_i < s_j)\ = 1 + sum_{j e i}frac 1{16}sum_{0 leq x1, x2, y1, y2 leq 1} [x_1a_{i, 1} + x_2a_{i, 2} < y_1a_{j, 1} + y_2a_{j, 2}] ]

    复杂度: (O(n^2))


    这一部分的代码


    (100 Pts)

    看上面那个式子 (j) 的枚举与 (x_1, x_2) 是不影响的 可以交换枚举的顺序

    [E_i = 1 + frac 1{16} sum_{0 leq x_1, x_2 leq 1}sum_{j e i}sum_{0 leq y_1, y_2 leq 1} [x_1a_{i, 1} + x_2a_{i, 2} < y_1a_{j, 1} + y_2a_{j, 2}] ]

    考虑里面的两个求和 当 (x_1a_{i, 1} + x_2a_{i, 2}) 确定之后就是求比其大的数的个数 将所有数存下来排个序 每次查询的时候二分

    复杂度: (O(nlog n))


    这一部分的代码


    T2 空间跳跃

    题解说 (dfs) 期望能通过 (40\%) 的数据 但是 BS 爆零了


    将构造过程反过来 看成从 (n)(1) 的构造 那么操作 (2, 3) 可以看成 (n = frac n2)(n = frac n3 + 1)

    题解说根据 (3n + 1) 猜想 对于给定的范围 只要 (n) 为偶数就让 (n = frac n2) 的话 正整数的 (n) 必然能到达 (1) 负整数的 (n) 必然能落到 (-1, -5, -17)

    (n) 的绝对值足够小之后可以使用操作 (1) 将其变为正整数 在使用操作 (2, 3)(n) 变为 (1)

    题解说通过验证这样的构造不会超过 (1500)


    代码


    T3 快速访问

    题目要求维护一个点集到某个点的距离的平方和

    直接差了

    [sum_{v in S}dis(u, v)^2 = |S|dep_u + sum_{v in S}dep_v^2 + 4sum_{v in S}dep_{lca(u, v)} + 2dep_usum_{v in S}dep_v - 4dep_usum_{v in S}dep_{lca(u, v)} - 4sum_{v in S}dep_vdep_{lca(u, v)} ]

    分别维护后面每一项即可

    后面那一坨东西的第一项 第二项 第四项是可以直接维护的 其他项可以通过树剖维护

    这里只补一个东西

    [sum_{i = 1}^k(2i - 1) = 2sum_{i = 1}^ki - k = 2 imes frac {(1 + k)k}2 - k = k^2 ]

    然后就可以直接做了


    代码


    T4 门童

    咕~

  • 相关阅读:
    join函数——Gevent源码分析
    代理上网(ssh 动态端口转发)
    内核热patch
    技术债
    mysql 隔离级别与间隙锁等
    python type
    django : related_name and related_query_name
    ssh 卡主
    logistics regression
    __new__ 和 __init__
  • 原文地址:https://www.cnblogs.com/blank-space-/p/15402314.html
Copyright © 2020-2023  润新知