zoukankan      html  css  js  c++  java
  • 题解12/12 模拟赛

    赛后1min过题\px

    Outer space invaders「CERC 2014」 [3]

    根据数据范围猜测 dp。先思考过只记一维时间,然后发现这样不太能知道到底哪些时段可行。考虑两维区间dp。记 \(f_{l,r}\) 代表时刻开区间 \((l,r)\) 内的所有进攻者都被消灭的最低成本。注意这里需要 \(l<a,b<r\),也就是完全包含。转移时必然要找到距离最远的一个,然后在某个 \(k\in [a_{max},b_{max}]\) 时刻以 \(d_{max}\) 的功率开放,那所有经过时刻 \(k\) 的进攻者都不需要考虑了,只需考虑 \((l,k),(k,r)\) 范围内的进攻者。于是得到 \(f_{l,r}=\min (f_{l,k}+f_{k,r}+d_{max})\)。这也是为啥使用开区间更方便。

    Hack Protection「NEERC 2013」 [3]

    枚举右端点,每一位独立考虑。那么 \(\&\) 和一定是先一段 \(0\) 然后一段 \(1\)。把分界线取出来,对每一位的分界线放一起排序,就可以知道每一段的 \(\&\) 的值。然后问题转化为求一段区间内等于某个数的数的个数。直接扫描线+哈希表即可。时空复杂度 \(O(n\log V)\)\(V\) 是值域。

    [BZOJ4973]比特战争 [3]

    首先不考虑边的限制(这也是我一开始理解的题意)。那么对于一个连通块,显然是找一个最便宜的地方买需求最多的地方的兵的数量。现在加上边的限制那么还需对瓶颈路,也就是最小生成树中最大的边的边权取 \(\max\)。由于这个边权可以特别大,我们还有另一种方法占领整个连通块——对于这条边的两侧分别占领。于是直接kruskal,每次合并时把答案与 \(\min(ans_u+ans_v,\max(w(u,v),\max a_x)*\min(b_x)),x\in S_u\cup S_v\)\(\min\)。其中 \(S_u\) 代表 \(u\) 当前的连通块集合。时间复杂度 \(O(n\log n)\)

    事后检查「ICPC World Finals 2019」 [7]

    暴搜+模拟,稍微剪枝即可通过。

  • 相关阅读:
    python数据类型以及模块的含义
    python基础语言以及if/while语句结构
    subprocess模块
    linux 管道通信socket 全双工示例
    整体框架
    licode_WebrtcConnection
    webrtc杂谈(转)
    修改背景颜色
    激活NX窗口的按钮
    NX屏蔽窗口的按钮
  • 原文地址:https://www.cnblogs.com/zcr-blog/p/15679019.html
Copyright © 2011-2022 走看看