首页 > 其他分享 >JOISC 2023 纪录

JOISC 2023 纪录

时间:2023-09-09 20:55:06浏览次数:51  
标签:纪录 复杂度 times JOISC 端点 2023 区间 红蓝 2i

记录一下 JOISC 2023 的做题记录

Day1 T1 Two Currencies

给定一棵树,在边上有总计 \(m\) 个检查站,经过一个检查站需要叫 \(1\) 枚金币或者若干枚银币。\(Q\) 次询问,问一个人有 \(X\) 枚金币和 \(Y\) 枚银币,能否从 \(u\) 走到 \(v\),同时回答最多可以留下多少枚金币。

发现一定是用银币卖掉价值路径上银币代价前 \(k\) 小的检查站,考虑用整体二分,使用树状数组维护重链剖分维护,时间复杂度 \(O(n\log^3n)\)。

Day1 T2 Festivals in JOI Kingdom 2

给出一个错误的贪心方式,问有多少种构造可以使得这个DP假掉。

首先我们要知道正确的 DP 怎么写。

将所有的区间按照右端点排序,每一次选择右端点最小且与没有与已经选择的区间有交的区间。

我们称正确的算法选中的区间为红区间,错误的算法选中的区间为蓝区间,两个算法都选择了的区间叫做紫区间,两个算法都没有选择的区间叫做黑区间。

显然,任何红区间两两无交,蓝区间两两无交。
而且,相邻的两个红区间的右端点之间不会包含任何的完整区间;相邻两个蓝区间的左端点之间不会包含任何区间的左端点。
我们不好考虑红区间比蓝区间多的情况,但是我们可以考虑他们相等的情况,然后用 \(\prod\limits_{i=1}^{N} (2*i-1)\) 减去即可。

则我们可以将红蓝区间两两配对,则红蓝数量相等的情况下,每一对红蓝区间必然有交。

我们还可以证明第 \(i\) 个红区间的右端点必然大于第 \(i-1\) 个蓝区间的右端点(否则红蓝无法匹配),必然小于第 \(i\) 个蓝区间的右端点(否则不满足正确算法的贪心)。

由于所有的红蓝区间是配对的,所以考虑依次插入每一对红蓝区间。

插入的同时,我们可以处理所有右端点在两次的红区间之间的所有黑区间,这些区间的左端点必然在上一个红区间的右端点之前。

所以我们需要设计状态:\(f_{i,k,0/1}\) 表示插入了前 \(i\) 个红蓝区间,预留了 \(k\) 个空位给黑区间的左端点。转移需要枚举插入的黑区间数 \(j\),复杂度是 \(O(n^3)\) 的。

枚举插入的黑区间数是不可避免地,考虑优化DP的状态。

我们发现我们专门用了一位 \(k\) 来维护黑区间的左端点,所以考虑反转整个过程,\textbf{从右向左}加入每一对红蓝区间,只需要保证插入的黑区间右端点在上一个红区间的右端点之后即可。而对于这些黑区间的左端点,只需要保证不在下一个区间的右端点和上一个区间的左端点之间即可。

考虑设计状态:\(f_{i,0/1}\) 表示插入了后 \(i\) 个区间,由多少种方案,转移枚举插入的黑区间数 \(j\)。

对于转移来源和转移结果的 \(0/1\) 状态不同,我们可以得到如下的四种转移:

\(f_{i+j+2,1}\gets f_{i+j+2,1}+f_{i,1}\times (j+1)\times (j+2)\times (2i-3+j)^{\underline{j}}\)。
\(f_{i+j+1,0}\gets f_{i+j+2,0}+f_{i,1}\times (j+1)\times (2i-3+j)^{\underline{j}}\)。
\(f_{i+j+2,1}\gets f_{i+j+2,1}+f_{i,0}\times (j+1)\times (2i-2+j)^{\underline{j}}\)。
\(f_{i+j+1,0}\gets f_{i+j+2,0}+f_{i,0}\times (2i-2+j)^{\underline{j}}\)。

这样就可以做到 \(O(n^2)\) 的复杂度,卡一卡常就可以通过了。
但是还可以优化,状态不可能再优化了,所以考虑优化转移。

例如对于第一个转移:
\(f_{i+j+2,1}+= f_{i,1}\times (j+1)\times (j+2)\times (2i-3+j)^{\underline{j}}\)

我们令 \(k=i+j+2\),可以得到:

\[\begin{matrix} f_{i,1}\times (j+1)\times (j+2)\times (2i-3+j)^{\underline{j}}\\ =f_{i,1}\times (j+1)\times (j+2)\times \frac{(2i-3+j)!}{(2i-3)!}\\ =\frac{f_{i,1}}{(2i-3)!}\times (i+k-5)!\times (k-i)\times (k-i-1)\\ =\frac{f_{i,1}}{(2i-3)!}\times (i+k-5)!\times \left[i^2+(1-2k)i+k^2-k\right]\\ =\left[\frac{i^2f_{i,1}}{(2i-3)!}+(1-2k)\frac{if_{i,1}}{(2i-3)!}+(k^2-k)\frac{f_{i,1}}{(2i-3)!}\right]\times (i+k-5)! \end{matrix}\]

发现式子中只有 \(i\) 和 \(i+k\),我们最终要得到的是 \(k\),典型的差卷积形式。
其他三个式子也是类似的,这样我们处理的问题就变成了一个半在线卷积的问题。
使用任意模数 NTT 可以做到 \(O(n\log ^2n)\),使用 Karatsuba 算法可以做到 \(O(n^{\log_23})\),均可通过此题。

Day1 T3 Passport

你可以在第 \(i\) 个国家消耗 \(1\) 的代价获得一个可以到达 \([L_i,R_i]\) 国家的通行证 \(L_i\leqslant i\leqslant R_i\),\(Q\) 次询问,问初始在第 \(X_i\) 个国家,至少需要消耗多少的代价才能到达任何国家。

由于 \(L_i\leqslant i\leqslant R_i\),所以只需要能够到达 \(1\) 和 \(N\) 就可以到达任何节点。
所以不难得到最终的行走方案是先一起走一段路,然后分叉分别走向 \(1\) 和 \(N\)。

例如考虑只走向 \(1\) 的情况,设 \(f_i\) 为从第 \(i\) 个节点走到 \(1\) 至少要几步,则可以得到转移 \(f_i=\min\limits_{j=L_i}^{R_i}f_j+1\),使用 Dijkstra 优化转移,用线段树合并优化建边。

时间复杂度 \(O(n\log^2n)\)。

Day2 T1 belt conveyor

Day2 T2 council

有 \(N\) 个议员和 \(M\) 个议题,每个人都对每个议题持支持或反对的态度,要选择一个主席和副主席,对于每一个议题,如果除两位主席外支持的人数不小于 \(\left\lfloor\dfrac{N}{2}\right\rfloor\),这个议题就会通过,问每一个人当主席的时候,最多会通过多少个议题。

发现对于某一个人为主席的时候,只有那些当前是 \(\left\lfloor\dfrac{N}{2}\right\rfloor\) 票的议题才有可能会因为副主席而不被通过,假设这些议题的集合为 \(T\)。

记每一个议员通过的议题构成集合 \(S_i\),则对于每一个 \(i\),要求 \(\max\limits_{i\neq j}(\operatorname{popcount}(T\& S_j))\)。

对于每一个数 \(S_i\),使用前缀和得到他的所有子集,每一个子集对应的答案就是他的 popcount,则最终我们就是要找到一个最大的 popcount,使得存在它的一个子集是有值的。

时间复杂度 \(O(m2^m+nm)\)。

Day2 T3 Mizuyokan 2

Day3 T1 Chorus

有 \(2N\) 只海狸唱歌,其中有 \(N\) 只唱高音,有 \(N\) 只唱低音,初始给定他们的位置,问至少要调换多少对海狸,才能使得可以将这个 \(2N\) 的序列分成 \(k\) 个子序列,每个子序列都是前 \(\dfrac{len}{2}\) 个为高音,剩下的唱低音。

将 \(AB\) 序列转化成一条折线,遇到一个 \(A\) 就向上走,遇到一个 \(B\) 就向右走。则对于一个满足条件的折线,要至少能找到这样一个序列 \(p_0,p_1,p_2\dots p_k\),其中 \(p_0=0,p_k=N\),要求点 \((p_{i-1},p_i)\) 在折线下方。对于一条不合法折线,它的代价就是和一个满足条件的折线的面积差的最小值。
我们设计状态 \(f_{l,k}\),表示当前处理到 \(p_k=l\) 时的答案。发现转移为 \(f_{r,k+1}=\min(f_{l,k}+S(l,r))\)。
发现 \(S(l,r)\) 具有凸性和包含性,所以 \(k\) 为可以 WQS 二分处理掉,然后发现 \(l\) 维可以斜率优化,复杂度 \(O(n\log V)\)。

Day3 T2 Cookies

有 \(N\) 中饼干,其中第 \(i\) 种有 \(A_i\) 个;现在要把所有的饼干装进盒子,有 \(M\) 种大小的盒子,问至少需要多少个盒子,才能让每个盒子装满且里面的饼干互不相同。

标签:纪录,复杂度,times,JOISC,端点,2023,区间,红蓝,2i
From: https://www.cnblogs.com/Xun-Xiaoyao/p/17670575.html

相关文章

  • 2023.9.9——每日总结
    学习所花时间(包括上课):9h代码量(行):0行博客量(篇):1篇今天,上午数学建模比赛,下午数学建模比赛。我了解到的知识点:1.学习使用excel的分列、分类汇总以及一些其他函数2.学习并完成zookeeper的安装;明日计划:1.完成数学建模比赛;2.完成HBase的安装;......
  • 20230909学习总结hbase命令大全
    bin/hbase进入hbaseShell命令模式create'student','Sname','Ssex','Sage','Sdept','course'创建student表,属性'Sname','Ssex','Sage','Sdept','course'put......
  • Adobe Lightroom Classic 2023最新(LrC12.5版本)安装下载
    AdobeLightroomClassic2023(LrC2023)使用针对桌面优化的应用程序编辑和整理您的照片。LightroomClassicCC为您提供强大的一键式工具和高级控件,让您的照片看起来很棒。轻松整理桌面上的所有照片,并以多种方式分享。迅雷云盘分享:https://pan.xunlei.com/s/VNdoEonKpUhx6XHs_H9Iw......
  • 2023-09-09学习记录
    NettyUnpooled疑惑Netty中的Unpooled类,ByteBufhttps://www.jianshu.com/p/dc7782cb31fcNettyChannelGroup疑惑ChannelGroup详解https://www.jianshu.com/p/0fead0912ef3Netty心跳知识点IdleStateHandleruserEventTriggered疑惑Netty实现心跳......
  • [羊城杯2023RE]WP
    目录ReverseCSGOvm_woEz加密器BlastReverseCSGOGo逆向静态不好看,考虑动调在main_init有IsDebuggerPresent反调试,nop掉看一眼findcrypt插件,识别到base64看看main_mainmain__Cfunc_enc_abi0是加密runtime_memequal是最后的check,base64完是60位说明flag为44位在81行下......
  • 2023-09-05 图论专项训练(五)
    我TM但凡有点水平也不至于一点水平没有吧。——每日感想T1距离/P4162[SCOI2009]最长距离这道题本质上是一道十分弱智的搜索题,无论是开DFS还是开BFS还是开BDFS都能做。本人在这里不建议使用使用deque进行BFS,理由是运行速度比较慢,稍有不慎就见祖宗了。我在这里使用DFS,但是纯......
  • 2023版标准地图
    水系名称字号规范按自然形状、走向注出、依其面积大小和长度选择字号,但江、河上游和支流的名称字号,不能超过下游和主流的名称字号,另外,名称一般注在河=流、湖泊的内部,当内部不能容纳时,可注在外侧地面河流a代表岸线,b代表高水位岸线湖泊有名称的应加注名称湖泊水是咸水(矿化......
  • SMU Autumn 2023 Round 1(Div.1)
    SMUAutumn2023Round1(Div.1)A.SetorDecrease(枚举)题意就是你可以进行两种操作,将\(a_i-1\)或者令\(a_i\)等于\(a_j\),然后使得\(\sum\limits_{i=1}^{n}a_i\leqk\),求最少的操作步数首先我们让一个大数变成一个最小数的贡献肯定是要比让大数减一产生的贡献更多,所以我......
  • SY2023CTF--“安洵杯”全国精英赛MISC--烦人的压缩包
    前言:由于最近要比第二届技能大赛CTF就玩的少(我很菜,求大佬带)随便看看做了一题那个数独也简单不敢兴趣就run了烦人的压缩包:首先下载下来一个压缩包需要密码直接爆破一下使用工具:Ziperello得到密码:645321解压打开得到两个文件hint.txt和love.jpg放入010Editor发现是有......
  • 20211325 2023-2024-1 《信息安全系统设计与实现(上)》第一周学习笔记
    202113252023-2024-1《信息安全系统设计与实现(上)》第一周学习笔记一、任务要求任务详情自学教材第1,2章,提交学习笔记(10分),评分标准如下1.知识点归纳以及自己最有收获的内容,选择至少2个知识点利用chatgpt等工具进行苏格拉底挑战,并提交过程截图,提示过程参考下面内容(4分)......