首页 > 其他分享 >2023-03-24-CQ 2023 省选前复习记录

2023-03-24-CQ 2023 省选前复习记录

时间:2023-07-05 12:14:05浏览次数:48  
标签:24 03 right limits nxt sum times 2023 left

伝えに来たよ 傷跡を辿って それなら もう恐れるものはないんだと.

CF449D

看来我确实只会做板题 /kk。
一个很 naive 的想法是定义 \(dp_{i, x}\) 表示当前到了第 \(i\) 位,与起来的值为 \(x\) 的方案数,显然这个做不下去,因为状态数会有重叠,并且这复杂度会爆。
一个不那么 naive 的想法是容斥,定义 \(f_i\) 是与值至少为 \(i\) 的方案数,\(g_i\) 表示恰好,所以有 \(g_i = f_i - \sum_{j \& i = i}g_j\) 。因为我们只要 \(g_0\) 。

\[\begin{aligned} ans = g_0 &= f_0 - \sum_{j = 1}^{2^n - 1} g_j \\ &= \sum_{i = 0}^{2^n-1} (-1)^{\mid i \mid} f_i \\ f_i = 2^{s_i} - 1&, s_i = \sum_{j = 1}^{n} [a_j \& i = i] \end{aligned} \]

目标是求 \(s_i\) ,记 \(cnt_i\) 表示 \(i\) 出现的次数。
然后直接对 \(cnt\) 进行 \(fwt\) 就可以得到 \(s_i\) 了。

UOJ266

首先把后续所有的 \(xor\) 记为 \(+\) 。
记 \(f(x)\) 表示以 \(x\) 为根的子树的 \(SG\) 函数的值, \(g(x, y)\) 表示以 \(x\) 为根的子树中第一步涂黑了 \(y\) 的后的 \(SG\) 值,记 \(sum(x) = \sum_{y \in x} f(y)\) 。
可以知道 \(g(x, y)\) 是子游戏 \(x\) 的一个后继局面集合。涂黑了 \(z\) 之后相当于从 \(z\) 到 \(y\) 之间的所有点都会被删去,那么这棵树就会被分成更多个子游戏,那么这些子游戏的 \(SG\) 函数的和就是 \(f(x)\) ,终止局面是 \(g(x, x) = sum(x)\) 。

但是这并不意味着需要把这个链上的所有点都跑一遍,因为已经记录了 \(g\) ,具体的转移是

\[g(x,z) = g(y,z)+\sum\limits_{y'\in son(x), z\notin subtree(y')} f(y') = g(y,z)+(\sum\limits_{y'\in son(x)} f(y'))+f(y)\space\space | \space\space z\in subtree(y) \]

[省选联考 2020 A/B 卷] 冰火战士

第一眼三分,第二眼发现有平台。
继续延续上面这个思路,用 fire 减去 ice 得到一条单调函数,于是我们可以在这个上面二分了。
但是这样是两个 \(\log\) 的,发现可以在线段数上二分,但是常数大了,于是改成树状树组倍增很可以过。

[省选联考 2020 A 卷] 组合数问题

需要转下降幂阿,但是我不会,于是学了一下。

\[\begin{aligned} &\left(\sum\limits_{k=0}^n \sum\limits_{i=0}^m a_i \times k^i\times x^k \times \dbinom{n}{k}\right)\bmod p \\ =&\left(\sum\limits_{k=0}^n \sum\limits_{i=0}^m a_i \times \sum\limits_{j = 0}^i \left\{^i_j\right\} \dbinom{k}{j}j!\times x^k \times \dbinom{n}{k}\right)\bmod p \\ =&\left(\sum\limits_{k=0}^n \sum\limits_{i=0}^m a_i \times \sum\limits_{j = 0}^i \left\{^i_j\right\} \dbinom{n-j}{k-j} \times \dbinom{n}{j}j!\times x^k \right)\bmod p\\ =&\left( \sum\limits_{i=0}^m a_i\sum\limits_{j=0}^i\left\{^i_j\right\}\times\dbinom{n}{j}j!\times \sum\limits_{k=0}^n\dbinom{n-j}{k-j}x^k \right)\bmod p \\ =&\left( \sum\limits_{i=0}^m a_i\sum\limits_{j=0}^i\left\{^i_j\right\}\times\dbinom{n}{j}j!\times (x+1)^{n-j}\times x^j \right)\bmod p \\ =&\left( \sum\limits_{i=0}^m a_i\sum\limits_{j=0}^i\left\{^i_j\right\}\times\frac{n!}{(n-j)!}\times (x+1)^{n-j}\times x^j \right)\bmod p \end{aligned} \]

[省选联考 2020 A 卷] 树

这确实不能直接看穿。

一个比较明显的想法是在知道了子结点的结果后用某种方式迁移到父节点上面。

于是我们需要这样一个玩意儿,对子树内的 \(w\) 整体加 \(1\) ,插入一个数,合并子树信息。

可以想到 0/1 trie ,插入和合并是平凡的,问题在于这个整体加一怎么做。

首先对于一棵子树,右儿子加一之后变成左儿子,左儿子变成右儿子,但是权值发生改变,具体来说是权值翻倍再异或右儿子权值翻倍。

注意终止结点的标记问题,有一些细节。

贴个代码。

struct Trie {
  int tot, rt[MAXN], nxt[MAXN * MAXM][2], cnt[MAXN * MAXM][MAXM], ed[MAXN * MAXM];
  void insert(int p, int ind, int val) {
    for (int i = 0; i < LIM; i++) {
      int tmp = (val >> i) & 1;
      cnt[ind][i] += tmp;
      if (!nxt[p][tmp]) nxt[p][tmp] = ++tot;
      p = nxt[p][tmp], ed[p]++;
    }
  }
  void update(int p, int ind) {
    for (int i = 0; i < LIM; i++) {
      if (!p) return;
      cnt[ind][i] += ed[nxt[p][0]], cnt[ind][i] -= ed[nxt[p][1]];
      swap(nxt[p][1], nxt[p][0]), p = nxt[p][0];
    }
  }
  int merge(int x, int y) {
    if (!x || !y) return x + y;
    ed[x] += ed[y];
    nxt[x][0] = merge(nxt[x][0], nxt[y][0]);
    nxt[x][1] = merge(nxt[x][1], nxt[y][1]);
    return x;
  }
} trie;

[省选联考 2020 A/B 卷] 信号传递

题面很烦,重新写一下。

\[\left\{ \begin{aligned} y - x, y > x \\ ky + kx, x \le y \\ \end{aligned} \right. \]

这样我们把整体的贡献拆成每个点的贡献,确切地说,对于最终坐标落在 \(x\) 上的点如果存在一条 \(x \le y\) ,若 \(x \le y\) 则付出 \(k\) 的代价,否则付出 \(-1\) 的代价。

可以写出这个表达式,但是很抽象,尝试动态分析这个过程,两种贡献方式分开讨论,假设我们有一条传输要求是 \(x \rightarrow y\) 。

第一种

\(x < y\) ,当 \(x\) 出现后,如果 \(y\) 在后续的过程中每一次没有出现就会多造成 \(1\) 的贡献,于是我们知道他们之间的距离就可以了。意思就是每一对有传输要求的都会在放置一个新的信号塔后产生 \(1\) 的贡献。

第二种

\(x > y\) ,对比第一种发现是 \(x, y\) 之间的距离再加上两倍 \(y\) ,那么 \(x, y\) 之间的距离可以和第一种一样地去计算,两倍 \(y\) 可以在每次加入点的贡献时计算。

代码有点搞人,因为你发现数组开不下,要拆成两个小的集合来做,不知道怎么会搞这个玩意儿。。。

[省选联考 2021 A 卷] 矩阵游戏

看起来很简单阿,我直接构造 \(a_{i, j} = b_{i - 1, j - 1} - a_{i - 1, j} - a_{i, j - 1} - a_{i - 1, j - 1}\) ,然后看到后面有个限制 \(\forall a \le 1e6\) 。

非常明显阿,有较强数量限制的构造,直接上差分约束,调整一下这个式子, \(b_{i, j} = a_{i, j} + a_{i + 1, j} + a_{i, j + 1} + a_{i + 1, j + 1}\) 这个是和约束,加入限制 \(1 \le a_{i, j} \le 1e6 \Rightarrow 1 \le b_{i, j} - a_{i + 1, j} - a_{i, j + 1} - a_{i + 1, j + 1} \le 1e6\) 。那么对 \(a_{i, j}\) 进行调整需要保证这个田字格中的和不变,注意到对每个点限制其实很不好做,并且 \(n, m \le 300\) 是常见的行列整体操作的数据范围,马上发现加上这样一个矩阵之后构造依然合法。

\[\left |\begin{array}{} c_1 + d_1, -c_1 + d_2, c_1 + d_3, -c_1 + d_4 \dots \\ c_2 - d_1, -c_2 - d_2, c_2 - d_3, -c_2 - d_4 \dots \\ c_3 + d_1, -c_3 + d_2, c_3 + d_3, -c_3 + d_4 \dots \\ c_4 - d_1, -c_4 - d_2, c_4 - d_3, -c_4 - d_4 \dots \\ \end{array}\right| \]

现在就好做了,于是我们黑白染色,对于白点 \((i + j) \& 1\) ,\(i \rightarrow^{a_{i, j}} j, j \rightarrow^{1e6 - a_{i, j}} i\) ,对于黑点 \(!((i + j) \& 1)\) ,\(i \rightarrow^{1e6 - a_{i, j}} j, j \rightarrow^{a_{i, j}} i\) 。

跑一边差分约束即可。

[省选联考 2020 A 卷] 作业题

掀起全机房写矩阵树定理狂潮。

看到这个式子很烦阿,起手把这个 \(\gcd\) 干掉,熟练地欧拉反演它,拿到的式子是

\[\begin{aligned} val(T) &= \left( \sum_{i = 1}^{n - 1}w_{e_i} \right) \times \sum_{d \mid \gcd(w_e)} \varphi(d) \\ ans &= \sum_{d} \varphi(d) \times \sum_{T, d \mid w_{e_i}, w_{e_i} \in T} \left( \sum_{i = 1}^{n - 1} w_{e_i} \right) \end{aligned} \]

然后问题是求后面那一块,我们是知道 \(\prod_{i = 1}^{n - 1} w_{e_i}\) 怎么求的,这个矩阵树定理就好了,然后大家都说乘积转和是个套路,我不会。

具体是你把 \(w_{e_i}\) 换成 \(w_{e_i} + 1\) ,然后你乘一下,\((w_1 + 1) \times (w_2 + 1) = (1) + (w_1 w_2) + (w_1 + w_2)\) ,这个式子的一次项就是我们要的东西,然后做完了。

标签:24,03,right,limits,nxt,sum,times,2023,left
From: https://www.cnblogs.com/Iridescent41/p/17528175.html

相关文章

  • 2023-03-17- 后缀自动机
    我直接忽略掉这个玩意的原理。或许我应该从自动机开始,更确切地说我应该从确定有限状态自动机(\(DFA\))开始。\(\mathbb{DFA}\)\(\mathtt{Definition}\)首先给出一些前置的定义。\(Q\),有限状态集合。\(\Sigma\),有限字符集。\(\delta\),转移函数,\(Q\timesE\rightarrow......
  • 2023-03-05-NOI 春测 游记
    终究是我的锅。/ll想了很久,不知道怎么写。最近遇到很多令人困惑的事,我现在也不是很能理解我在那一天早上发生了什么?总之我心情很不好就是了。考试之前发生了什么都忘了,因为早上起来头有点晕。下面是整个考试的经历。before没进考场时心态还是比较稳健,但是当我真正坐下来......
  • 2023-03-05-CQOI 2023 省选 游记
    心高气盛难免对自己抱有幻想。Before2023-04-01上接2023春测。以及停课时模拟赛复习。2023-04-01来得比较早,听游老师强调了一些低级错误,然后吴老师过来给我们打气。心理稍微稳了一点,合了影就去考场了。中途发生了一个小插曲,我以为桌子上写的是座位号,于是坐在了......
  • 2023-02- NOI 春测复习记录
    Tosaygoodbyeistodiealittle.由于不可抗拒力,复习计划咕咕咕了。也不一定呢?P4755link关键在于要发现暴力的复杂度是对的。好像这个方法叫做\(\max\)分治,首先可以建一个大根的笛卡尔树,然后只需要对该点的管辖区间进行计算就可以了。具体做法是直接以最大值的点\(......
  • 2023-01-26-Poly Template
    尝试强行记忆,尝试失败。。。把最终所有的式子写一遍。约定\(F^{*}(x)\)表示\(\pmod{x^{n/2}}\)意义下的结果,\(F^{R}(x)\)表示系数翻转。\(\mathtt{Summary}\)\(\mathtt{Poly\INV}\)\[G(0)=F(0)'\\G(x)=G^{*}(x)(2-F(x)G^{*}(x))\]\(\mathtt{Poly\Sqrt}\)\[......
  • 成语积累 20230705
    焚膏继晷:焚:点燃;膏:灯油或蜡烛;继:接续;晷:日影或日光。意思是点燃灯烛来接替日光照明。形容夜以继日的用功读书或努力工作。例句:~,兀兀穷年。鹤唳华亭:表示思念,怀旧之意。亦为慨叹仕途险恶,人生无常之词。例句:但~,贵何似贱;珠沉金谷,富不如贫。拾人牙慧:牙慧:牙齿内剔出的余食。比喻拾取别人......
  • Springboot No bean named 'XXXXX' available 问题解决
    一、问题描述近日在工作中遇见了一个bug,后端程序频频报错Nobeannamed'XXXXX'available。对比同类程序文件,没有发现有任何特殊之处。在网上搜索方法基本上就是扫描包配置、注解问题、路径问题等,皆不能解决我的问题。排查问题是发现出现问题的类命名不符合驼峰规范,按照这个......
  • 早期癌症筛查测试行业市场现状及未来发展趋势2023
    2023年全球及中国早期癌症筛查测试行业头部企业市场占有率及排名调研报告本文调研和分析全球早期癌症筛查测试发展现状及未来趋势,核心内容如下:(1)全球市场早期癌症筛查测试总体规模,按收入进行了统计分析,历史数据2018-2022年,预测数据2023至2029年。(2)全球市场竞争格局,全球市场头部企......
  • 2023-07-05 Matlab中的数值积分.md
    2023-07-05Matlab中的数值积分Matlab数值积分在《计算方法》一书中有介绍基本的数值分析中的积分方法,我们这里重点关注Matlab是如何帮助我们快速计算数值积分。1.integral簇函数integral簇函数下包含integral,integral2,integral3三个函数,分别对应于一重积分,二重积分和......
  • 【2023-07-02】连岳摘抄
    23:59其实,偶然并不存在,你必须得到某个东西时,它的出现绝非偶然,而是你自己,你自己的渴望和需求将你引向那里。                                                 ——黑塞......