传送门

写在前面:为了保护正睿题目版权,这里不放题面,只写题解。


dlstql,wsl


  • A

\(10pts:\)

\(a=100,T=100\),对每个排列构造一个反的,一步到位即可。

\(20pts:\)

\(a=50\),构造\(1\)和所有元素交换的排列,实现交换\((v,u)\)可以令两者分别与\(1\)交换,选择排序即可。

\(40pts:\)

\(a=30\),构造前\(25\)个元素与\(1\)交换的排列,另有一个排列交换前\(25\)个与后\(25\)个元素。

\(a=20\)时可以分三块处理。

\(100pts:\)

考虑\(a=2\),步数不限时怎么做。

只需构造一个\(2-n\)的环,再构造一个\(1-2\)的交换。

每次可以把位置\(1\)上的数放到它在循环里的对应位置。

但是一步的期望是\(\frac{n}2\)次操作,实际步数无法承受。

考虑倍增。由于\(a=5\)的限制,难以二进制倍增,可以考虑三进制倍增。

【update:经过同学们反映,必须用dls的\(\{1,3,8,20\}\)才能获得满分】

一步的期望大约是\(4.5\)次操作,随机数据下可以通过。


  • B

欣赏一下swk的神奇错误:

\(\frac{1}n \sum(a_i-\frac 1n \sum a_i)^2=\frac{1}{n}(\sum a_i^2+\frac{(1-2n)(\sum a_i)^2}{n^2})\)

/cy/qiang

显然方差直接算是不可做的,考虑拆一下式子。

\(\frac{1}n \sum(a_i-\frac 1n \sum a_i)^2=\frac{1}{n}\sum(a_i^2-\frac {2a_i}n\sum a_i +\frac{1}{n^2}(\sum a_i)^2)=\frac 1n (\sum a_i^2-\frac{1}n (\sum a_i)^2)\)

即,对于一个确定的大小为\(n\)的集合,它的方差为\(\frac 1n (\sum a_i^2-\frac{1}n (\sum a_i)^2)\)。

如果只需要算一个方差,有上式就够用了。然而此处我们要算的是区间内所有子集的方差。

\(\frac 1n (\sum a_i^2-\frac{1}n (\sum a_i)^2)=\frac{n-1}{n^2}\sum a_i^2-\frac{1}{n^2}\sum_{i\not=j}a_ia_j\)

设每次求取区间长度为\(l\),枚举子集大小\(n\),考虑区间内每个\(a_i\)单独出现的次数,即\(l\)个数中选\(n\)个,其中\(a_i\)必选的方案数,等价于\(l-1\)个数中选\(n-1\)个的方案数。

同样,区间内每对\(a_i,a_j\)出现的次数为\(l-2\)个数中选\(n-2\)个的方案数。

由此得到长度为\(l\)的区间所有子集的方差和\(=\sum_{n=1}^{l}\frac{n-1}{n^2}(^{l-1}_{n-1})\sum a_i^2-\sum_{n=1}^l\frac{1}{n^2}(^{l-2}_{n-2})\sum_{i\not=j}a_ia_j\)。

发现枚举\(a_i,a_j\)比较困难,重新将其转化为完全平方的形式,得到\(\sum_{n=1}^{l}\frac{n-1}{n^2}(^{l-1}_{n-1})\sum a_i^2-\sum_{n=1}^l\frac{1}{n^2}(^{l-2}_{n-2})[(\sum a_i)^2-\sum a_i^2]\)。

整理得\(\sum a_i^2 \sum_{n=1}^l [\frac{n-1}{n^2}(^{l-1}_{n-1})+\frac{1}{n^2}(^{l-2}_{n-2})]+(\sum a_i)^2\sum_{n=1}^l\frac{1}{n^2}(^{l-2}_{n-2})\)。

发现原式被拆分成了形如\(x_l\sum a_i^2+y_l(\sum a_i)^2\)的形式,且\(x_l,y_l\)与序列形态无关,只与序列长度有关。现在原问题转化为两个子任务:维护区间和,区间平方和;迅速求解\(x_l,y_l\)。

第一个子任务可以用线段树简单维护。

将\(x_l\)拆分成三部分:①\(\sum_{n=1}^{l}\frac{1}{n}(^{l-1}_{n-1})-\)②\(\sum_{n=1}^{l}\frac{1}{n^2}(^{l-1}_{n-1})+\)③\(\sum_{n=1}^{l}\frac{1}{n^2}(^{l-2}_{n-2})\),则\(y_l\)是\(x_l\)的一部分。考虑分别求解。

①:\(\sum_{n=1}^{l}\frac{1}{n}(^{l-1}_{n-1})=\sum_{n=1}^{l}\frac{(l-1)!}{n!(l-n)!}=\sum_{n=1}^{l}\frac{1}{l}(^l_n)=\frac{2^l-1}{l}\)(注意\(n\)的枚举从\(1\)开始)

②:\(\sum_{n=1}^{l}\frac{1}{n^2}(^{l-1}_{n-1})=\frac 1l\sum_{n=1}^{l}\frac{1}{n}(^l_n)\),发现不是很好求解,可以使用差分的技巧。设\(P_l=\sum_{n=1}^{l}\frac{1}{n}(^l_n)\),则\(P_{l+1}-P_l=\frac 1{l+1}+\sum_{n=1}^{l}\frac{(^{l+1}_{~~n})-(^l_n)}{n}=\frac 1{l+1}+\sum_{n=1}^{l}\frac{1}{n}(^{~~~l}_{n-1})=\frac{1}{l+1}(1+\sum_{n=1}^l(^{l+1}_{~~~n}))=\frac{2^{l+1}-1}{l+1}\)

③:\(\sum_{n=1}^{l}\frac{1}{n^2}(^{l-2}_{n-2})=\frac{1}{l(l-1)}\sum_{n=1}^l\frac{n-1}{n}(^l_n)=\frac{1}{l(l-1)}(2^l-1-\sum_{n=1}^l\frac{1}{n}(^l_n))\),发现与②式形式相同,可以简单处理。


  • C

dls:昨晚睡迷糊了,所以写了两份错的题面。

\(50pts:\)

按右端点排序dp,考虑需要记录哪些状态。

发现需要记录:未被覆盖的区间中,右端点最靠左的;选中的区间中,右端点最靠右的。维护这两维状态,转移时枚举当前线段是否选,直接做就可以,复杂度\(O(n^3)\)。

\(100pts:\)

可以通过离散化,把端点改成两两不同的。

对每条线段求出\(l_i,r_i\),分别表示它左右两边第一条不能覆盖的线段。

可能会有右端点\(>r_i\),但是左端点较远所以被\(i\)覆盖的线段。发现它并不会影响答案,因为\(r_i\)完全被这条线段包含,因此任何覆盖\(r_i\)的线段都会覆盖它。

此时我们把每条线段转化成了一个区间,要求选出若干区间,使他们的并为\([1,n]\)。

然后dls翻车了两次233333

显然区间右端点单调不降。设\(f_{i,j}\)为考虑了前\(i\)个区间,最左的未被覆盖的点为\(j\)的方案数。

转移时,发现\(f_{i,[1,l_i)}\)无论选与不选都不会受到影响,\(f_{i,[l_i,r_i]}\)只有不选才会保留,\(f_{i,r_i+1}\)若选,则会从\(f_{i,[l_i,r_i]}\)处转移来。

因此需要维护一个数据结构,支持区间乘法,区间和,线段树即可。复杂度\(O(m\log n)\),虽然\(n\)很大,但是在\(\log\)上,所以可以通过。

ZROI 19.08.11模拟赛的更多相关文章

  1. ZROI 19.08.07模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "正睿从来没有保证,模拟赛的题目必须原创." "文案不是我写的,有问题找喵老师去."--蔡老师 ...

  2. ZROI 19.08.09模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. A \(70pts:\) 维护一个栈,从一侧向另一侧扫描,如果新加入的元素与当前栈顶相同,则出栈,否则进栈.显然一个子串是括号序列,当 ...

  3. ZROI 19.08.06模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. 今天正睿又倒闭了,从删库到跑路. 天祺鸽鸽txdy! A "不要像个小学生一样一分钟就上来问东西."--蔡老板 虽 ...

  4. ZROI 19.08.12模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "我发现问题的根源是大家都不会前缀和."--敦爷 A 敦爷spj写错了,差点把蒟蒻swk送走 \(50pts:\) ...

  5. ZROI 19.08.10模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. A \(20pts:\) 枚举操作序列然后暴力跑,复杂度\(O(6^n)\). \([50,80]pts:\) 枚举改成dfs,每层操 ...

  6. ZROI 19.08.05模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. A \(21pts:\) 随便枚举,随便爆搜就好了. \(65pts:\) 比较显然的dp,设\(f_{i,j,k}\)表示在子树\( ...

  7. ZROI 19.08.04模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. "这应该是正睿OI历史上第一次差评破百的比赛." "这说明来正睿集训的人越来越多了." &qu ...

  8. ZROI 19.08.08模拟赛

    传送门 写在前面:为了保护正睿题目版权,这里不放题面,只写题解. 首先恭喜swk今天翻车! "小心大样例演你."--天祺鸽鸽 果然swk今天被大样例演死了,天祺鸽鸽诚不欺我! A ...

  9. 2019.11.11 模拟赛 T2 乘积求和

    昨天 ych 的膜你赛,这道题我 O ( n4 ) 暴力拿了 60 pts. 这道题的做法还挺妙的,我搞了将近一天呢qwq 题解 60 pts 根据题目给出的式子,四层 for 循环暴力枚举统计答案即 ...

随机推荐

  1. [Cinder] 存储 Qos

    目录 文章目录 目录 前言 操作步骤 参考文章 前言 Cinder 支持 front-end 和 back-end 两种类型的存储 QoS,前者由 Hypervisor 端实现(e.g. 通过 Lib ...

  2. SAE Django如何禁止外部IP访问

    在SAE上基于Django搭建的Web工程有时需要禁止来自某些特定IP地址的访问请求. 例如一个为搭建在SAE的其他项目提供服务的内部工程,可以设置为只允许SAE内部的IP地址访问,从而提高项目的安全 ...

  3. Java Array数组 遍历 四种方式(包含 Lambda 表达式遍历)

    示例代码如下: package com.miracle.luna.lambda; import java.util.Arrays; /** * @Author Miracle Luna * @Date ...

  4. SAS数据挖掘实战篇【七】

    SAS数据挖掘实战篇[七] 6.5  SAS EM数据挖掘-----预测模型 1  问题定义 目标:建立模型预测贷款申请的信用状态,选择最优的模型来预测和减少损失. 数据集:SAMPSIO.DMAGE ...

  5. Spring Boot 自定义注册 Servlet、Filter、Listener

    前言 在 Spring Boot 中已经移除了 web.xml 文件,如果需要注册添加 Servlet.Filter.Listener 为 Spring Bean,在 Spring Boot 中有两种 ...

  6. C++类大小的计算

    这里记录一下怎么计算类对象的大小. 大概总结下,类的大小需要考虑以下内容: 非静态成员变量大小 数据对齐到多少位 有无虚函数(即需不需要指向虚函数表的指针,如果考虑继承的情况,则还需要看继承了多少个指 ...

  7. python 并发编程 多线程 信号量

    一 信号量 信号量也是一把锁,可以指定信号量为5,对比互斥锁同一时间只能有一个任务抢到锁去执行,信号量同一时间可以有5个任务拿到锁去执行 如果说互斥锁是合租房屋的人去抢一个厕所,那么信号量就相当于一群 ...

  8. Linux下面误删除文件使用extundelete工具恢复介绍

    操作系统版本:CentOS release 6.4 (Final)      软件版本:extundelete-0.2.4.tar.bz2 PS:该软件恢复文件系统仅支持ext2/ext3/ext4 ...

  9. 一道并发和锁的golang面试题

    今天面试golang碰到了一道考并发和锁的题目,没有完成,所以把它记录下来,仅为以后复习. 场景:在一个高并发的web服务器中,要限制IP的频繁访问.现模拟100个IP同时并发访问服务器,每个IP要重 ...

  10. AtCoder,Codeforces做题记录

    AGC024(5.20) 总结:猜结论,“可行即最优” B: 给定一个n的排列,每次可以将一个数移到开头或结尾,求变成1,2,...,n所需的最小步数. 找到一个最长的i,i+1,...,j满足在排列 ...