ZROI 19.08.10模拟赛
写在前面:为了保护正睿题目版权,这里不放题面,只写题解。
- A
\(20pts:\)
枚举操作序列然后暴力跑,复杂度\(O(6^n)\)。
\([50,80]pts:\)
枚举改成dfs,每层操作后还原。复杂度\(O(3^n)\)。
全0或全1可以直接返回。
写法优秀可以过\(80pts\)。
\(100pts:\)
类似非递归fft的写法,bitrev后可以位运算优化。
最下面四层可以预处理,复杂度\(O(3^{n-4})\)。
然后疯狂卡常就完事了(
然而由于swk人菜常数大,明明所有剪枝都加上了仍然挂掉了qwq
破案了,原来swk太菜了,在递归的每一层都重构了一遍结构体,结构体里还用了vector,于是多了\(12\)倍常数,就死掉了。
- B
\(80pts:\)
枚举最小差,设为\(d\)。
统计最小差大于等于 \(d\) 的集合最大差之和,发现对于一个最小差为\(x\)的集合,它的最大差刚好被统计了\(x\)次。
直接dp,设\(f_i\)表示前\(i\)个元素,且第\(i\)个元素必选的最大差之和。转移时需要一堆前缀和。我代码写的特别诡异
\(100pts:\)
仍然枚举\(d\),对每个\(d\)枚举集合元素个数\(x\),发现\(dx\leq n\),所以枚举复杂度为\(O(n\log n)\)。
然后随便组合数一下就可以了。
发现集合中的最大值和最小值是对称的,可以分开算。
考虑枚举最小值为\(c\),则方案数为\((^{n-c-x(d-1)}_{~~~~~~~~x-1})\)。即选中\(x\)个元素,在它们后面附带\(d-1\)个额外的空格,其中位于位置\(c\)的元素必须被选中,且前面不能有任何被选中的元素,可以直接把这个元素删掉。
设\(a=n-x(d-1),b=x-1\),则总贡献为\(\sum_{c=1}^{a-b} c\cdot (^{a-c}_{~~~b})=\sum_{c=b}^a (a-c)\cdot (^c_b)=\sum_{c=b}^a (a+1)\cdot(^c_b)-(c+1)\cdot (^c_b)\)。
将后半部分拆开,得到\((c+1)\cdot (^c_b)=\frac{(c+1)c!}{b!(c-b)!}=(b+1)\frac{(c+1)!}{(b+1)!(c-b)!}=(b+1)\cdot(^{c+1}_{b+1})\)。
代回上式,得到\(\sum_{c=b}^a (a+1)\cdot(^c_b)-(b+1)\cdot (^{c+1}_{b+1})=(a+1)\cdot(^{c+1}_{b+1})-(b+1)\cdot(^{c+2}_{b+2})\)。可以\(O(1)\)计算。
- C
swk完全不会做找观察题所以光荣爆零了。然而大家都切了这道题,所以swk菜死了。
一个很重要的结论就是每个点只会往上走。
感性理解下就是越往上边就越稀疏。
于是每个点只有\(O(\log)\)个点与它相关,建出边直接跑就可以了。
上面的写法比较麻烦。好写一点的方法是,两个点必然在lca附近相遇。对每个点可以算出向上不经过桥最近的祖先,贪心地找最高的祖先即可。需要特判两个点在祖先的两侧相遇的情况。
ZROI 19.08.10模拟赛的更多相关文章
- ZROI 19.08.07模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "正睿从来没有保证,模拟赛的题目必须原创." "文案不是我写的,有问题找喵老师去."--蔡老师 ...
- ZROI 19.08.09模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. A \(70pts:\) 维护一个栈,从一侧向另一侧扫描,如果新加入的元素与当前栈顶相同,则出栈,否则进栈.显然一个子串是括号序列,当 ...
- ZROI 19.08.06模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. 今天正睿又倒闭了,从删库到跑路. 天祺鸽鸽txdy! A "不要像个小学生一样一分钟就上来问东西."--蔡老板 虽 ...
- ZROI 19.08.04模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "这应该是正睿OI历史上第一次差评破百的比赛." "这说明来正睿集训的人越来越多了." &qu ...
- ZROI 19.08.12模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "我发现问题的根源是大家都不会前缀和."--敦爷 A 敦爷spj写错了,差点把蒟蒻swk送走 \(50pts:\) ...
- ZROI 19.08.11模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. dlstql,wsl A \(10pts:\) \(a=100,T=100\),对每个排列构造一个反的,一步到位即可. \(20pts ...
- ZROI 19.08.05模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. A \(21pts:\) 随便枚举,随便爆搜就好了. \(65pts:\) 比较显然的dp,设\(f_{i,j,k}\)表示在子树\( ...
- ZROI 19.08.08模拟赛
传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. 首先恭喜swk今天翻车! "小心大样例演你."--天祺鸽鸽 果然swk今天被大样例演死了,天祺鸽鸽诚不欺我! A ...
- ZROI 19.08.02 杂题选讲
给出\(n\)个数,用最少的\(2^k\)或\(-2^{k}\),使得能拼出所有数,输出方案.\(n,|a_i|\leq 10^5\). 显然一个绝对值最多选一次.这个性质非常强. 如果所有都是偶数, ...
随机推荐
- MySQL 创建函数报错 This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creators
问题描述 通过Navicat客户端,创建MySQL函数(根据的当前节点查询其左右叶子节点)时报错,报错信息如下: This function has none of DETERMINISTIC, NO ...
- 什么是 go vendor
go vendor 是golang引入管理包依赖的方式,1.5版本开始引进,1.6正式引进. 基本原理其实就是将依赖的包,特指外部包,复制到当前工程下的vendor目录下,这样go build的时候, ...
- 哈希表 HashTable(又名散列表)
简介 其实通过标题上哈希表的英文名HashTable,我们就可以看出这是一个组合的数据结构Hash+Table. Hash是什么?它是一个函数,作用可以通过一个公式来表示: index = HashF ...
- python--008文件处理
一.文件操作 1.打开文件,获得文件句柄,并将句柄赋值给一个变量 2.通过句柄对文件操作 3.关闭文件 f=open('sg',encoding='utf-8') da=f.read() print( ...
- H3C版本升级
H3C S5500和S3100都可以通过TFTP方式进行升级,1.设置交换机的vlan1的ip地址,如10.10.10.2/242.设置电脑和交换机连接的ip地址,如10.10.10.1/243.在交 ...
- linux scp放后台执行方法
客户要搭建异地的容灾dg,压缩备份集500G,只能使用scp,前台跑经常超时,使scp放后台跑完成相关的文件传输: FULLBAK_LFCXJMYB_20190507_6448_1.DBFILE 10 ...
- 从MAP角度理解神经网络训练过程中的正则化
在前面的文章中,已经介绍了从有约束条件下的凸优化角度思考神经网络训练过程中的L2正则化,本次我们从最大后验概率点估计(MAP,maximum a posteriori point estimate)的 ...
- 匿名函数、委托和Lambda表达式
匿名函数 匿名函数(Anonymous Function)是表示“内联”方法定义的表达式.匿名函数本身及其内部没有值或者类型,但是可以转换为兼容的委托或者表达式树类型(了解详情).匿名函数转换的计算取 ...
- [转帖]小米手环采用RISC-V 指令集芯片
小米手环4或用“黄山一号”芯片,雷军再回前线,未来走向如何 静心科技 06-1111:19 忘记来源地址了 不过国内的很多东西都是有中国特色的 比如飞腾 比如麒麟(银河麒麟 还有华为的麒麟 980) ...
- python3 修改大数据量excel内容
最好使用python3 64位 对excel的修改操作: from openpyxl import load_workbook import time #打开一个excel表格.xlsx wb = l ...