ZJOI2020
[ZJOI2015] 地震后的幻想乡
给定一个无向图 \(G\) ,\(n\) 个点 \(m\) 条边每条边权为 \([0,1]\) 的随机实数,求这张图的最小生成树的最大边权期望。
\(1\le n\le 10,1\le m\le \frac{n(n-1)}{2}\) 。
Solution
引理 \(1\) :
\(n\) 个 \([0,1]\) 随机变量 $x_1,\cdots,x_n $ ,第 \(k\) 小的期望值是 \(\frac{k}{n+1}\)
证明:枚举第 \(k\) 小值为 \(x\) :\(\binom{n}{k}\int_0^1x \cdot x^{k-1}\cdot (1-x)^{n-k} dx=\frac{k}{n+1}\) 。
暴力枚举 \(m\) 条边的相对大小关系,套引理即可做到 \(\mathcal O(m!poly(n))\) 。
考虑状压 dp ,定义 \(f_{S,i},g_{S,i}\) 表示点集 \(S\) ,用了 \(i\) 条边,且点集不连通/连通的方案数,\(d_{S}\) 表示点集 \(S\) 导出子图的边数。
考虑 \(f\) 的转移,我们枚举一个连通块(不妨是 \(lowbit(S)\) 所属的那个块),其他的点之间任意连边,则: \(f_{S,i}=\sum\limits_{lowbit(S) \in T\subset S}\sum\limits_{j=0}^{|d_T|}g_{T,j}\binom{|d_{S-T}|}{i-j}\)
注意到 加了 i 条边恰好连通概率 = 加之前不连通概率 - 加之后不连通概率 ,因此答案为:
\]
时间复杂度 \(\mathcal O(3^nm)\) 。
Day1
T1
给定一个由字符 \(\text{'a', 'b'}\) 构成的字符串 \(str\) 。
一个串为好串的定义是:串长为偶数,且左右两半相等。比如说 \(abcdeabcde\) 就是好串。
有 \(q\) 次询问,询问区间 \([l,r]\) 内有多少个本质不同的好串(也就是一模一样的好串只算 \(1\) 次)。
\(1\le n,q\le 2\times 10^5\)
T2
给定一颗广义线段树,读入按中序遍历的方式告诉你每根线段 \([l,r]\) 的 \(mid\) 值。
你需要执行 \(k\) 次 选区间 操作,每次等概率选择一个区间 \([ql, qr]\) 满足 \(1\le ql\le qr\le n\) ,并且相应在线段树上打懒标记。
对于每个区间 \([ql, qr]\),执行 \(\text{modify(1, 1, n, ql, qr)}\) :
void pushdown(int u) {
if (tag[u]) {
tag[lson[u]] = 1;
tag[rson[u]] = 1;
tag[u] = 0;
}
}
void modify(int u, int l, int r, int ql, int qr) {
if ([l, r] ∩ [ql, qr] = 空集) return ;
if (ql <= l && r <= qr) {
tag[u] = 1;
return ;
}
int mid = 读入的 mid 值;
pushdown(u);
if (ql <= mid) modify(lson[u], l, mid, ql, qr);
if (qr > mid) modify(rson[u], mid + 1, r, ql, qr);
}
请求出期望下线段树中 \(tag\) 值为 \(1\) 的线段的个数。
\(n\) 在 \(10^5\) 级别, \(1\le k\le 10^9\) 。
T3
给定一个长度为 \(n\) 的序列 \(a_1,a_2,...,a_n\),你可以执行以下三种操作:
- 选择一个区间 \([l,r]\) ,让区间内的数全减 \(1\)
- 选择一个区间 \([l,r]\) ,让区间内下标是奇数的数全减 \(1\)
- 选择一个区间 \([l,r]\) ,让区间内下标是偶数的数全减 \(1\)
你需要最小化你的操作次数,使得所有数变成 \(0\) 。
Day2
T1
\(Alice\) 和 \(Bob\) 在 树/基环树 上的游戏。。。
题面有点长,咕咕
T2
给定 \(n\) 个数 \(a_1,a_2,...,a_n\) ,每次等概率选择一个数(选过的数下次可能还会被选)。
问期望下取多少次数,才能出现 \(k\) 个连续的数(也就是满足 \(a_{i_1},a_{i_2},a_{i_3},...\) 依次 \(+1\))?
\(1\le n\le 2\times 10^5, 1\le a_i\le 10^9\)(好像)
T3
给定 \(n\) 个方程组,参数 \(a_i,c_i\)。
\]
给出一个扰动 \(err\) ,每个 \(p_i\) 均为 \([\lceil - \frac{err}{2} \rceil, \lceil \frac{err}{2} \rceil]\) 内随机的一个数。
你需要找到一个 \(x\) ,使得它满足上述所有条件。
数据保证有且仅有一个 \(x\) 满足条件。
\(n=2000, 1\le a_i,c_i,p\le 10^{18}\)
如果要用 \(\text{__int128}\) ,请手写。
ZJOI2020的更多相关文章
- P6631 [ZJOI2020] 序列
可以将问题用形象的方式来表述.给定一排点,第 \(i\) 个点有它需要的覆盖次数 \(a_i\).有两种线段,一种能覆盖连续的一些点,称其为连续线段:另一种能覆盖相邻间隔为 \(1\) 的一些点,称其 ...
- [ZJOI2019]游记之我的第一次省选--自闭记
2019/3/23 day -1 今天是体育中考....(祝我好运) 实心球再次投出测量范围,虽然成绩是10.5,但是目测有15米. 立定跳远2.70,好近,我爸叫我跳2.8的QwQ. 1000米最后 ...
- Lyndon 相关的炫酷字符串科技
浅谈从 Lyndon Words 到 Three Squares Lemma By zghtyarecrenj 本文包括:Lyndon Words & Significant Suffixes ...
随机推荐
- 一个chome的广告拦截小插件
先附上下载地址:https://chromecj.com/productivity/2015-03/391.html 可以屏蔽绝大多数广告啊,浏览器用起来神清气爽! 下载完成后有一个名字为这个的文件, ...
- MySQL数据库设置编码格式和时区
MySQL数据库设置编码格式和时区 MySQL5版本: url=jdbc:mysql://localhost:3306/test?characterEncoding=utf-8 MySQL6版本及以上 ...
- python---实现单例模式
""" 单例模式 单利模式是一种设计模式, 应用该模式的类只会生成一个实例, 可以保证在程序的不同位置 都可以且仅可以取到同一个对象实例. 如果实例不存在, 会创建一个实 ...
- 导出带标签的tar包(docker)-解决导出不带标签的麻烦
需求:在docker的本地镜像库中导出tar包给其他节点使用. 如果使用:docker save -o package.tar e82656a6fc 这样形式导出的tar包,安装之后标签会消失解决办法 ...
- linux权限问题,chmod命令
Linux系统中,每个用户的角色和权限划分的很细致也很严格,每个文件(目录)都设有访问许可权限,利用这种机制来决定某个用户通过某种方式对文件(目录)进行读.写.执行等操作. 操作文件或目录的用户,有3 ...
- 新手小白入门C语言第二章:基本语法
1. 语句 C 语言的代码由一行行语句(statement)组成.语句就是程序执行的一个操作命令.C 语言规定,语句必须使用分号结尾,除非有明确规定可以不写分号. 如: int x = 1; 这就是一 ...
- vue 排错
error The template root requires exactly one element vue/no-multiple-template-root ... 解决办法: .eslint ...
- springboot:使用异步注解@Async的前世今生
在前边的文章中,和小伙伴一起认识了异步执行的好处,以及如何进行异步开发,对,就是使用@Async注解,在使用异步注解@Async的过程中也存在一些坑,不过通过正确的打开方式也可以很好的避免,今天想和大 ...
- 【mq】从零开始实现 mq-03-引入 broker 中间人
前景回顾 [mq]从零开始实现 mq-01-生产者.消费者启动 [mq]从零开始实现 mq-02-如何实现生产者调用消费者? [mq]从零开始实现 mq-03-引入 broker 中间人 上一节我们学 ...
- ucore lab6 调度管理机制 学习笔记
这节虽叫调度管理机制,整篇下来主要就讲了几个调度算法.兴许是考虑到LAB5难,LAB6就仁慈了一把,难度大跳水.平常讲两节原理做一个实验,这次就上了一节原理.权当大战后的小憩吧. schedule函数 ...