首页 > 其他分享 >2021 Summer Petrozavodsk Camp, Day 3 IQ test (XXII Open Cup, Grand Prix of IMO)

2021 Summer Petrozavodsk Camp, Day 3 IQ test (XXII Open Cup, Grand Prix of IMO)

时间:2023-05-09 15:11:29浏览次数:50  
标签:Summer XXII frac 个点 submission Cup 子集 bitset dp

AND

先看最小值是不是所有的子集,如果不是就无解,否则把剩下的中间塞一个最小值就好了。

submission

Math

移项,平方差变成 \(a_j=(k-a_i)(k+a_i)\),爆枚 \(k-a_i\) 和 \(k+a_i\) 就是 \(O(A\ln A)\) 的。

submission

Fancy Formulas

首先我们发现操作不改变 \((a+b)\bmod p\),因此如果两个不一样就无解。

一个手完一下就可以发现的事情是操作 \(k\) 次之后第一个数形如 \(2^ka-q(a+b)\),其中 \(q\in[0,2^k)\)。因为 \(p\) 是质数,所以可以枚举 \(k\) 然后计算出 \(q\) 看看在不在这个范围内。当 \(k>\log p\) 的时候就一定有解了。时间复杂度 \(O(T\log ^2p)\)。

submission

Hamiltonian

没意思,想一想大概可以想出这样几个构造:

  • \(n\) 个点的完全图:\(\frac{n(n-1)}{2}\)。
  • \(n\) 个点的完全图有一个点挂出一个点:\(n-1\)
  • \(n\) 个点的完全图有两个点同时连向第 \(n+1\) 个点:\(\frac{n(n+1)}{2}-1\)
  • \(n\) 个点的完全图挂出 \(m\geq 2\) 个点的链:\(\frac{n(n+3)}{2}+m-4\)

然后大概把这四种情况拼起来就覆盖了 \([1,60]\) 了。

submission

Glory Graph

看上去这两种情况分开算是没有办法算的,看看相减有没有办法能抵消掉某些项。

以下图片中实线表示一种颜色,虚线表示另一种颜色,没有连边表示任意。

image

前一种只需要枚举对角两个点然后看和他们分别连不同颜色的点的个数,第二种只需要枚举实线两端点然后看均连另一种颜色的点的个数即可。都可以 bitset ,时间复杂度 \(O(\frac{n^3}{\omega})\)。

submission

Deleting

首先有一个比较愚蠢的 dp :设 \(dp_{i,j}\) 表示将 \([i,j]\) 区间消去最小代价,大概是两种转移:

  • \(i,j\) 匹配,有 \(\max(cost_{i,j},dp_{i+1,j-1})\to dp_{i,j}\)
  • \(i,k\) 匹配,有 \(\max(dp_{i,k},dp_{k+1,j})\to dp_{i,j}\)

这是 \(O(n^3)\) 的并且不太好上一般 dp 的优化方法。所以我们考虑万能 bitset,他真的好喜欢bitset

具体的,我们从小到大计算 \(dp_{i,j}\) 的值,当我们确定 \(dp_{i,j}\) 的值之后考虑扩展。

第一种转移是平凡的,第二种转移以往右转移为例,你需要找到一个位置 \(k\),使得 \(dp_{j+1,k}\) 被计算过,并且 \(dp_{i,k}\) 没有被计算过,这可以用 bitset 的 & 操作和 Find_firstFind_next 来实现。

然后大概就做完了,时间复杂度 \(O(\frac{n^3}{\omega})\),如果带个 \(n^2\log n\) 有可能会被卡常,以及 CF 上 \(64\) 位语言的 bitset 特别慢。

submission

Eulerian

挺神秘的。

发现具有神秘的 \(60\) 次询问,不知道能干吗。

唯一能考虑的似乎只有欧拉回路的充要条件:每个点度数为偶数且联通。联通题目里已经保证了,只需要考虑度数的问题。

大概会联想到某些著名的随机 hash 题比如 CF1746F,判每个都是偶数可以变成判子集加和,单次正确率是 \(\frac{1}{2}\),二项式定理容易证明。

所以我们只需要能对一个随机子集计算其度数之和的奇偶性即可。

我们考虑问出这个子集内的边数 \(a\) 以及其补集的边数 \(b\) ,那么在这两个点集之间的边数就是 \(m-a-b\)。这个数的奇偶性与这个子集的度数和奇偶性一致,因为子集内的边贡献两次。

所以我们可以问 \(29\) 个子集,正确率 \(1-2^{-29}\) 可以接受。

submission

Intellectual Implementation

牛逼题,场上写出来的队真的太厉害了!

首先因为这是个 IQ 场,所以应该不是大力数据结构的题。仿照 G 的思路先容斥,现在我们需要数三个点之间有一条边,两条边,三条边的个数。

一条边和两条边的三元组个数都需要求出和某个矩形相交的矩形个数,考虑这个怎么求。二维的问题太困难了,扫描线转化成一维问题。和某个矩形相交的大概就两类:在这个矩形的上边出现之前上边就出现了的,和上边出现了之后再出现的,这个可以按照 \(x\) 坐标排序,然后变成求和某个线段相交直线有多少的问题,转化成求不交只需要一条线段左端点大于另一个右端点即可,都可以树状数组维护。

但是三条边就不是那么好做的了。我们考虑选择最上边最下面的矩形的最上边考虑,这时依然转化成线段问题,我们要求的是与 \([u_i,d_i]\) 相交的线段中相交的对数。考虑选取相交区间的最右边的点计算,则假设某个点被覆盖 \(a\) 次,那么对答案贡献 \(a\choose 2\) 次。

这样会算重啊?没关系,我们说过只在最右边的点考虑,因此可以减去每个区间右端点缩小 \(1\) 之后的贡献,就是恰好在相交区间右端点取到的贡献。你需要写一个线段树支持区间加,区间查询平方和,则维护二次项和,一次项和,常数和即可。

时间复杂度 \(O(n\log n)\) 拥有巨大常数。submission

标签:Summer,XXII,frac,个点,submission,Cup,子集,bitset,dp
From: https://www.cnblogs.com/275307894a/p/17385078.html

相关文章

  • 【题解】XX Open Cup, GP of Moscow
    //createdon23.03.26目录A.AliceandBobB.BracketsC.CirclesD.DejaVuE.EasiestSumF.FunnySalesmanG.GraphColoringH.HiddenGraphI.InsectsJ.JoiningPointsA.AliceandBob对于链上的情况,异色点是一定不会选择走进同色段的(长度不小于\(2\)),因为一定不优。......
  • 【SD集训】20230425 T2 差(difference) 题解 CF1500F 【Cupboards Jumps】
    大家可以猜猜看为什么有两个标题,因为这个原因本文就不设密码了,被He_ren的原题创到了。吐槽一下,He_ren甚至出原题还用脚造数据,虽然数据确实比较难造。不过那两个\(O(n^2)\)老哥好像都没最后将所有数调整成非负,遗憾20。有人场切*3500却没过签到题,我不说是谁。题目描述......
  • The 1st Universal Cup. Stage 12: Ōokayama
    G容斥完之后发现要求一个m次多项式的n次方,并且得到\(n\timesm\)项。原本很sb地直接套了个多项式LnExp上去(即使知道大概率过不了),然后狂TLE。。。其实但凡从常数的角度分析,Exp的常数有14倍,已经比\(log(m)\)大了,所以不如写快速幂,然后写着就会发现卷积的长度总和其实是\((n\times......
  • 基于cups 协议实现一个灵活的无线打印
    以前实际上简单介绍过基于cups进行网络打印的处理的,以下是一个相对完整方案,可以实现相对完整的管理(也比较简单,但是基本够用)参考图 备注:以上扩展支持了多端,通过基于cups管理多个打印机,默认cups可以支持text,image,pdf打印,为了方便实现office周边的打印,包含了一个文档转换......
  • Codeforces Round 850 (Div. 2, based on VK Cup 2022 - Final Round) E. Monsters (h
    传送门详细题解传送门  抄的ygg代码,向在这里说一下刚开始没看懂的部分。  求答案的时候是把所有的当前为止的所有数值加起来减去一个从1开始并且公差为1的等差数列的前size项和。其中size是当前最多能用到哪个位置,满足前size项能构成1,2,3,....,sz这样的形式。  假设我们......
  • Codeforces Round 625 (Div. 1, based on Technocup 2020 Final Round) A. Journey Pl
    https://codeforces.com/contest/1320/problem/AA.JourneyPlanning题目大意:给定一组数,问我们ai-aj==i-j的时候就可以把ai的值加起来,问我们可以凑到的最大总值是多少?input6107191015output26input1400000output400000input7892611122914out......
  • cups+ippserver+cups4j 进行ipp 打印测试
    cups是一个打印标准,ippserver属于一个测试mock的ipp服务(基于软件的),cups4j是cups的一个客户端环境准备具体配置参考github,实际配置来自ippsample的测试配置version:"3"services:ippserver:image:dalongrong/ippserverhostname:ippse......
  • docker 运行cups 服务
    主要是一个简单测试,方便学习环境准备docker-composeversion:"3"services:cups:image:olbat/cupsdprivileged:trueports:-"632:631"volumes:-./cupsd.conf:/etc/cups/cupsd.conf-/var......
  • 使用cups + ipp 协议client 进行网络打印处理
    实际上日常中我们已经使用了网络打印了(比如公司内部使用的共享打印机),现在大家会有使用基于部分厂商开发的的网络打印进行资料打印从技术实现上基本都是基于网络打印技术,然后通过控制程序对于打印机进行操作,然后平台会按照不同的打印模式收取不同的费用,用户可以自己去固定网点去取......
  • HNU2019 Summer Training 3 E. Blurred Pictures
    E.BlurredPicturestimelimitpertest2secondsmemorylimitpertest256megabytesinputstandardinputoutputstandardoutputDamonlovestotakephotosoftheplaceshevisitsduringhistravels,toputthemintoframes.Allofhisphotosarei......