zoukankan      html  css  js  c++  java
  • 省选模拟42 题解

    A. coin

    容易发现每种假钞的期望贡献是独立的。

    对于每种假钞,做一个 $n^2$的 dp 求出来选择 $i$张假钞的贡献。

    然后对这个贡献做一个背包就完事了。

    考虑一个东西,就是对于每种假钞,只能选择一个数目加入背包的贡献中。

    所以可以考虑对于每种假钞一张张加入贡献。

    然后发现发现随着某种假钞的数量增加,期望增加量是不断减少的。

    所以不断取最优策略进行更新就好了。

    B. B

    容易发现问题就是与给定树重合边数 $geq n-1-k$ 的树的个数。

    似乎是显然的变元矩阵树定理,然后搞个拉格朗日插值就完事了。

    但是蒟蒻太菜了,所以思路比较清奇,发现这个玩意就是个二项式反演。

    钦定一个边集,然后问题就转化为若干个连通块的生成树计数。

    设有 $m$个连通块,然后每个连通块大小分别为 $size_i$,然后这个生成树个数有个结论就是 $n^{m-2} prod limits_{i=1}^m size_i$。

    然后发现这个玩意的瓶颈就是如何钦定 $k$条边,考虑搞一个 dp。

    显然对于那个 $n^{m-2}$ 可以把 $n$ 摊在每个连通块里乘上一个 $n$。

    然后可以写一个简单的子树归并,$dp_{i,j,k}$ 表示 $i$ 子树中,钦定了 $j$ 条边,最后一个连通块有 $k$ 个点的总贡献。

    转移的时候分钦定连在一起,不钦定那么给权值乘上一个 $n*k$ 就完事了。

    分析一下复杂度,是 $O(n^4)$ 的。

    然后考虑一下实际含义,这个乘 $size_i$ 其实就是对于每个连通块选择其中一个定为特殊点。

    然后可以改一下 dp定义,$dp_{i,j,0/1}$ 表示 $i$ 子树中,钦定了 $j$ 条边,最后一个连通块是否选择了特殊点。

    直接子树归并,复杂度就是 $O(n^2)$ 的了。

    C. battery

    考虑如果一个炮台能打到别的炮台,那么这个方向就结束了。

    然后每个炮台有两个方向,要求就是 $a xor b=1$。

    如果有 $k$ 个炮台钦定方向之后就能打到一个空地,那么要求就是 $x_1 or x_2 or x_3 or x_{,,}=1$。

    然后发现这个玩意就不会做了。

    然而实际上并不存在 $k>2$ 个炮台都能打到一个空地的情况。

    因为炮台不能相互打到的限制,每个空地的横向和纵向显然只能有一道射线能射过来。

    然后问题就转化为了简单的 2-SAT 问题,写个 tarjan 就完事了。

  • 相关阅读:
    VMware 中安装Centos
    go with go
    [APIO2012]派遣【左偏树】
    后缀自动机三·重复旋律6
    AC自动机(二次加强版)
    [HAOI2016]找相同字符【GSAM广义后缀自动机】
    吉司机线段树【学习笔记】
    [ZJOI2015]诸神眷顾的幻想乡【GSAM】
    广义后缀自动机(广义 SAM)【模板】
    Important Sisters【HDU-4694】【Dominator Tree】
  • 原文地址:https://www.cnblogs.com/skyh/p/12458847.html
Copyright © 2011-2022 走看看