zoukankan      html  css  js  c++  java
  • ljq的互测の题解

    自己的互测还tm出锅了555
    自闭了。。。

    题解:

    朱德の战争 (war)

    画一画图可以发现,最后的关系一定是两两互为合作伙伴。这样才有可能保证任意两个不同的城市合作伙伴不同。否则由于原图没有环,到后面必定会撞上。然后直接 dfs 一遍就能得到匹配关系或者判断无解。合作伙伴都确定了就很简单了。对于每个点 (i),它的合作伙伴 (u) 的危险度肯定比它连接的其他点 (v_i) 的危险度小,就可以从 (u)(v_i) 连边。因为有危险度的限制,我们可以直接根据限制从叶节点开始遍历,因为叶节点的合作伙伴必须是它的父节点。可以用堆维护当前入度为 (0) 的点中编号最小的来保证字典序最小。

    时间复杂度 (O(nlog n))

    朱德の串儿 (string)

    个人认为这是个线性 DP​ 好题。

    (f[i][j]) 表示当前字符匹配到了第 (i) 位,Jude 匹配到了第 (j) 位时候的最小代价。

    状态转移方程如下:

    [f[i][j] = egin{cases} f[i-1][j] & mbox{if s[i]} eq s[j-1] \ min(f[i-1][j-1],f[i-1][j])+a[i] & mbox{if }s[i]=s[j-1] end{cases} ]

    最后要求的就是 (min(f[n][1sim 4]))

    时间复杂度 (O(n))

    朱德の序列 (sequence)

    我们可以枚举 (l),看 (r) 在哪里可以取到。

    如何处理最大公约数呢?我们可以把 (a_{ldots r})(gcd) 前缀和分组,相同的分为一组,这样我们在每组内只需要找到满足 ( ext{xor}_{i=l}^r a_i=frac{k}{gcd}) 即可。

    所以可以将程序分为以下几个步骤:

    1. (i≥l),找到最大的 (j≥i), 使得 (gcd(a_{ldots i})=gcd(a_{ldots i+1})=dots =gcd(a_{ldots r}))

      直接倍增预处理区间 (gcd),找的时候按倍增的方法往后跳就行了。

    2. 区间异或:预处理异或前缀和即可。

    3. 在区间内找异或相等:用 ( ext{map}) 即可实现。

    时间复杂度 (O(n log^2 n)),它的常数可能有点大。

  • 相关阅读:
    TreeView控件应用(包含递归调用)
    FTP操作(FTPClient)
    利用正则表达式 进行字符的判断
    复合查询
    NPOI操作
    导航特效
    拼音检索
    项目中的注意事项
    计算文件的MD5值上传到服务器 下载验证文件是否被篡改
    OLE Automation (C#读取EXCEL)
  • 原文地址:https://www.cnblogs.com/11haonb/p/11699351.html
Copyright © 2011-2022 走看看