\(\mathscr{Summary}\)

  有意思的是, 难度诈骗居然在我身上打出了暴击.

  (首先还是吐槽一下 \(5\text h\) 的模拟赛因为早读和早课变成 \(4\text h\) 这档事, 确实比较乱节奏.)

  A 题签得挺快. B 被论文诈骗根本没有从过题角度思考. C 确实傻了, 感觉形式很想 Boruvka 就可劲儿编做法, 发现做不来可劲儿写 LCT, 最后得到了暴力 Kruskal 的乞丐分.

  强制每到题用一个固定的时间思考满分算法或许是不错的选择. 毕竟不过几题垫底就稳了.

\(\mathscr{A\sim}\) 轻松的音乐

  给定 \(\{p_n\},\{a_n\}\), 对于每个 \(i\), 其可以用一个区间覆盖 \([i-p_i,i)\) 或者 \((i,i+p_i]\), 求未必覆盖的 \(a\) 之和的最小值.

  \(n\le5\times10^4\), \(m:=\max\{p_i\}\le30\).


  考场上一眼的 \(\mathcal O(nm^2)\): 令 \(f(i,j,k)\) 表示考虑了 \(1..i\) 的区间, 假设 \((i-j,i]\) 被后面的区间覆盖, 当前覆盖到 \([i,i+k)\) 时的最小和. 转移很简单.

  这个算法慢在完全用 DP 进行策略优化, 事实上可以加入一些底层贪心. 令 \(f(i,j)\) 表示考虑了前 \(i\) 个区间, 覆盖到 \(j\) 的最小和. 仍然是讨论 \(i\) 区间的方向, 简单处理一下转移可以做到 \(\mathcal O(nm)\).

\(\mathscr{B}\sim\) 论文题

  给定 \(\{a_n\}\), 初始有 \(a_i\) 个颜色为 \(i\) 的球. 每一时刻在所有球中均匀随机两个不同且有序的球 \(x,y\), 将 \(x\) 的颜色变为 \(y\) 的颜色. 求所有球同色时的期望时刻. 答案模 \((10^9+7)\).

  \(n\le2.5\times10^3\), \(m:=\max\{a_i\}\le10^5\).


  Tags:「A.DP-概率/期望 DP」「B.Tricks」

  法一 上势能. 设 \(A\) 为一个局面下颜色的出现次数集合, 定义

\[\Phi(A)=\sum_{a\in A}\varphi(a).
\]

这里做出了把势能摊到每种颜色上的初步转化. 令常数 \(s=\sum_{a\in A}a\), 考虑一次操作得到的 \(A^*\):

\[\Phi(A^*)=\sum_{a\in A}\frac{a(a-1)+(s-a)(s-a-1)}{s(s-1)}\varphi(a)+\frac{a(s-a)}{s(s-1)}(\varphi(a-1)+\varphi(a+1)).
\]

我们自然希望 \(\Phi(A^*)=\Phi(A)-1\). 为了研究 \(\varphi\) 而不是 \(\Phi\), 可以把常数 \(-1\) 正比于 \(a\) 地摊到每个 \(\varphi(a)\) 上, 然后令变化前后对应的 \(\varphi\) 值两两相等. 化简后得到:

\[2\varphi(a)=\varphi(a-1)+\varphi(a+1)+\frac{s-1}{s-a}.
\]

这个还是比较好算. 引入差分 \(\delta(a)=\varphi(a)-\varphi(a-1)\), 则:

\[\delta(a+1)=\delta(a)-\frac{s-1}{s-a},\delta(0)=0.
\]

我们得到了递推势能的方法. 对于终结状态 \(A_t=\{s\}\),

\[\Phi(A_t)=\varphi(s)=-\sum_{i=1}^s\sum_{j<i}\frac{s-1}{s-j}=-\sum_{j=1}^ss-1=-s(s-1).
\]

最终 \(\Phi(A_0)-\Phi(A_t)\) 就是答案了. 线性求逆元可以做到 \(\mathcal O(n+m)\).

  对于势能法奏效的数理基础, 可以参考 21 年论文《鞅与一类关于停时的概率与期望问题》.

  法二 更加机械化的做法. 还是设 \(s=\sum a_i\), 令 \(f(x)\) 表示最初有 \(x\) 个球拥有被钦定的最终颜色时, 所有球都变成这一颜色的期望时刻 (钦定失败则令时刻为 \(0\)), 那么

\[f(x)=\begin{cases}
0 & x=0\lor x=s\\
\frac{x(x-1)+(s-x)(s-x-1)}{s(s-1)}f(x)+\frac{x(s-x)}{s(s-1)}(f(x-1)+f(x+1))+1, & \text{otherwise}
\end{cases}.
\]

然后和法一一样初等地算一算就行.

\(\mathscr{C}\sim\) 最小生成树

  给定 \(\{a_n\}\) 和边集 \(E=\{(u,v,w)_m\}\), 进行 \(q\) 次修改, 每次令 \(a_x\gets y\), 随后求出 \(G=([0..n],E\cup\{(0,i,a_i)\}_{i=1}^n)\) 的 MST 边权和.

  \(n,m,q\le3\times10^5\).


  Tags:「A.图论-生成树」「B.Tricks」

  在 \(E\) 中加入足量 \(+\infty\) 边使其能让 \(G\) 连通. 取 \(E\) 构成的 MST, 维护出 Kruskal 算法的等效链 (树转链, 两个图上 Kruskal 的表现相同).

  现在只需要对于链求答案. 线段树维护区间上一个 \(f(0/1,0/1)\) 信息, 表示区间左侧连通块是否与 \(0\) 连通, 右侧连通块是否与 \(0\) 连通, 此时的最小代价. \(\mathcal O((n+m)\log (n+m)+q\log n)\).

Solution Set -「NOI Simu.」2022.07.21的更多相关文章

  1. Solution Set -「ARC 107」

    「ARC 107A」Simple Math   Link.   答案为: \[\frac{a(a+1)\cdot b(b+1)\cdot c(c+1)}{8} \] 「ARC 107B」Quadrup ...

  2. Solution -「NOI 2021」「洛谷 P7740」机器人游戏

    \(\mathcal{Description}\)   Link.   自己去读题面叭~ \(\mathcal{Solution}\)   首先,参悟[样例解释 #2].一种暴力的思路即为钦定集合 \ ...

  3. Solution -「NOI 2020」「洛谷 P6776」超现实树

    \(\mathcal{Description}\)   Link.   对于非空二叉树 \(T\),定义 \(\operatorname{grow}(T)\) 为所有能通过若干次"替换 \( ...

  4. Solution -「NOI 2016」「洛谷 P1587」循环之美

    \(\mathcal{Description}\)   Link.   给定 \(n,m,k\),求 \(x\in [1,n]\cap\mathbb N,y\in [1,m]\cap \mathbb ...

  5. Solution -「NOI 2012」「洛谷 P2050」美食节

    \(\mathcal{Description}\)   Link.   美食节提供 \(n\) 种菜品,第 \(i\) 种的需求量是 \(p_i\),菜品由 \(m\) 个厨师负责制作,第 \(j\) ...

  6. Solution -「NOI 2008」「洛谷 P3980」志愿者招募

    \(\mathcal{Description}\)   Link.   一项持续 \(n\) 天的任务,第 \(i\) 天需要至少 \(a_i\) 人工作.还有 \(m\) 种雇佣方式,第 \(i\) ...

  7. Solution -「NOI 2018」「洛谷 P4768」归程

    \(\mathcal{Description}\)   Link.   给定一个 \(n\) 个点 \(m\) 条边的无向连通图,边形如 \((u,v,l,a)\).每次询问给出 \(u,p\),回答 ...

  8. Diary -「NOI 2021」酱油记

    雨幕浓稠 远近一白 是水雾弥漫的天 还是泡沫撑起的海   雨真大呢.   前几天去 ZH 中学集训没啥好记的,就从会合日开始叭. [Day -1]   逃出 ZH,掉入梦麟.(   高中的同学们忘记带 ...

  9. 「BZOJ 2434」「NOI 2011」阿狸的打字机「AC自动机」

    题意 有一个打字机,支持三种操作: 字符串末尾加一个小写字母 字符串末尾减一个字符 输出这个字符串 经过不超过\(n\)次操作后有\(m\)组询问:\((x,y)\),表示第\(x\)次输出第字符串在 ...

  10. 「BZOJ 3242」「NOI 2013」快餐店「基环树」

    题意 基环树上找到一个点(可以在边上)使得它到树上最远点的距离最小,输出最小距离 题解 如果是一棵树,答案就是树的直径\(/2\) 如果是基环树,那么很好证明删去环上的某一条边是不影响答案的.于是断环 ...

随机推荐

  1. uni-app 监听返回按钮

    前置条件: 开发环境:windows 开发框架:uni-app , H5+,nativeJS 编辑器:HbuilderX 2.8.13 4. 兼容版本:安卓,IOS已作测试 进入正题: 文档地址uni ...

  2. C语言实战项目——学生试卷分数统计

    1.题目要求 作为教师,考试以后对试卷进行分析和研究是必须做的一项工作,假定某学校要求老师在考试之后填写的一个表格,并要求教师根据考试分数分布情况画出直方图.下面就来解决这个实际问题. 2.题目分析 ...

  3. 使用 FastGPT 工作流搭建 GitHub Issues 自动总结机器人

    如今任何项目开发节奏都很快,及时掌握项目动态是很重要滴,GitHub Issues 一般都是开发者和用户反馈问题的主要渠道. 然而,随着 Issue 数量的增加,及时跟进每一个问题会变得越来越困难. ...

  4. 3.2 Linux文件系统到底有什么用处?

    Linux 上常见的文件系统是EXT3或EXT4,但这篇文章并不准备一上来就直接讲它们,而希望结合Linux操作系统并从文件系统建立的基础--硬盘开始,一步步认识Linux的文件系统. 1.机械硬盘的 ...

  5. 2.10 破解密码这么简单,Linux是安全的操作系统吗?

    很多人看到系统修复模式这节内容时,都会有所感慨:Linux 的密码破解太容易了,这样的操作系统还安全吗?Linux 不是以安全性著称的吗? 图 1 密码安全 本节,我们结合图 1 解释一下类似的问题. ...

  6. Linux Shell_函数

    目录 简要介绍 系统函数 basename direname 自定义函数 基本语法 简要介绍 shell编程和其它编程语言一样,有系统函数,也可以自定义函数.系统函数中,我们这里就介绍两个. 系统函数 ...

  7. getExplorerInfo:获取浏览器信息

    function getExplorerInfo() { let t = navigator.userAgent.toLowerCase(); return 0 <= t.indexOf(&qu ...

  8. JUC (Java Util Concurrency) 基础内容概述

    目录[-] 转自:http://www.goldendoc.org/2011/05/juc/ 1. JUC概况 2. 原子操作 3. 指令重排 4. Happens-before法则:(Java 内存 ...

  9. 从几个sample来学习Java堆,方法区,Java栈和本地方法栈

    最近在看<深入理解Java虚拟机>,书中给了几个例子,比较好的说明了几种OOM(OutOfMemory)产生的过程,大部分的程序员在写程序时不会太关注Java运行时数据区域的结构: 感觉有 ...

  10. 如何正确使用 RMQ

    序列分块.设块长为 \(B\).每块预处理出最大值.对于询问 \([l, r]\),答案就是整块最大值和散块最大值拼起来.答案显然是 \(O(n) \sim O(\dfrac{n}{B} + B)\) ...