首页 > 其他分享 >SWERC 2021-2022 部分简要题解

SWERC 2021-2022 部分简要题解

时间:2022-09-18 20:47:17浏览次数:130  
标签:le 2022 题解 pastebin 2021 https ubuntu 矩形 com

比赛链接:https://codeforc.es/contest/1662

前言

「部分」「简要」题解。

A - Organizing SWERC

直接判断。

C - European Trip

如果不考虑限制,我们可以直接矩乘。

考虑加入限制后怎么做。

设 \(F_{i,j}^{(k)}\) 为 \(i\to j\) 走 \(k\) 步且满足题目限制的方案数,\(I\) 为单位矩阵,\(D\) 为度数矩阵,\(G\) 为图的邻接矩阵。

那么有:

  • \(F_{i,j}^{(0)}=[i=j],F_{i,j}^{(1)}=G\);
  • \(F_{i,j}^{(2)}=\sum G_{i,k}G_{k,j}(i\ne j),F_{i,i}^{(2)}=0\);
  • \(\forall k\ge 2,F_{i,j}^{(k)}=\sum F_{i,l}^{(k-1)}G_{l,j}-F_{i,j}^{(k-2)}(deg_j-1)\)。

前两条应该都很好理解。

对于第三条,前面一部分可以理解为枚举 \(j\) 前面的一个点,后面就相当于减去 \(j\) 前面的第二个点也是 \(j\) 的情况,这时候 \(j\) 前面的一个点不能等于 \(j\) 前面的第三个点。也就是说,设走过的序列是 \(i\to\cdots\to l\to j\to k\to j\),那么只有当 \(k\ne l\) 时才能被统计进去。而 \(l\) 可以是 \(j\) 连接的任意一条边的另一个顶点,而 \(k\) 此时就有 \(deg_j-1\) 种选择。

把式子写成矩阵相乘的形式,就变成了 \(F_k=F_{k-1}\times G-F_{k-2}\times(D-I)\)。

可以像广义斐波那契数列那样矩乘,不过矩阵内部还套了一层矩阵。

代码:https://pastebin.ubuntu.com/p/88fjTW9HGN/

D - Evolution of Weasels

手玩可以发现 ABBABCAC 之间都可以相互转换。

那么我们可以把所有的 B 放到字符串的最后面,判断它们的奇偶性是否相等。

对于前面的只需要用栈模拟删除的过程,最后判断是否相等就行了。

代码:https://pastebin.ubuntu.com/p/zFhghTB4Mp/

F - Antennas

可以把式子拆开,变成 \(i\) 与所有 \([i-p_i,i+p_i]\) 之间的点连边。

由于边权都是 \(1\),所以我们可以 BFS。

复杂度瓶颈在于枚举出边,需要想办法优化这个过程。

由于连的边是一个区间,所以不难想到使用线段树优化这个过程。

讨论一下 \(i\) 与连边的 \(j\) 的大小情况:

  • \(j<i\),那么 \(i-j\le\min(p_i,p_j)\),即 \(i-j\le p_i,i-j\le p_j\),移项得 \(j\ge i-p_i,j+p_j\ge i\)。维护区间 \(j+p_j\) 的最大值,在 \([i-p_i,i-1]\) 中对所有 \(j+p_j\ge i\) 的 \(j\) 进行松弛。
  • \(j>i\) 的情况类似,转化出来是 \(j-p_j\le i,j\le i+p_i\)。维护区间 \(j-p_j\) 的最小值,在 \([i+1,i+p_i]\) 中对所有 \(j-p_j\le i\) 的 \(j\) 进行松弛。

代码:https://pastebin.ubuntu.com/p/5XS7WGyjY3/

I - Ice Cream Shop

每一个人存在贡献的都是一段区间,离散化后扫描线一遍即可。

代码:https://pastebin.ubuntu.com/p/SzXSZWVkng/

L - Il Derby della Madonnina

如果在观察 \(i\) 后能观察到 \(j\),那么需要满足 \(|a_i-a_j|\le (t_j-t_i)v\),拆开绝对值就相当于 \(a_i+t_iv\le a_j+t_jv,\ t_iv-a_i\le t_jv-a_j\)。

那么问题就相当于对所有 \((a_i+t_iv,t_iv-a_i)\) 的二元组求 LIS。可以对第一维排序,然后在第二维上跑序列上的 LIS 即可。

代码:https://pastebin.ubuntu.com/p/txRDWrTfBJ/

N - Drone Photo

如果我们把选出矩形同一行 / 列的两个点由值小的向值大的连边,那么不难发现合法的矩形会有 \(1\) 个点入度为 \(2\),不合法的矩形会有 \(2\) 个点入度为 \(2\)。并且所有矩形都只有这两种情况。

从小到大加入点,统计出 \(r_i,c_j\) 分别表示这一行 / 列比 \(a_{i,j}\) 小的元素个数,那么在 \((i,j)\) 处就会有 \(r_ic_j\) 种方案使得它入读为 \(2\)。设 \(S=\sum r_ic_j\) 表示所有矩形入度为 \(2\) 的点数的总和,\(C=(\frac{n(n+1)}{2})^2\) 表示所有矩形个数。若有 \(x\) 个矩形合法,那么 \(x+2(C-x)=S\),解得 \(x=2C-S\)。

代码:https://pastebin.ubuntu.com/p/n8MyHwy6mZ/

标签:le,2022,题解,pastebin,2021,https,ubuntu,矩形,com
From: https://www.cnblogs.com/xsl19/p/swerc2021-2022-sol.html

相关文章

  • 2022-2023-1 20221409 《计算机基础与程序设计》第三周学习总结
    这个作业属于哪个课程:首页-2022-2023-1-计算机基础与程序设计-北京电子科技学院-班级博客-博客园(cnblogs.com)这个作业的要求在:https://www.cnblogs.com/rocedu......
  • CSP2022游记
    初赛Day0数学考了124分,吃枣药丸。再不退役whk要没了。Day1一点钟到机房发现发了J组题目,看了看发现自己并不能很快地理解阅读T3的牛顿迭代和T2的鹰蛋问题。感觉如果去......
  • 2022CSP-J初赛游记
    2022年9月16日:下午,在学校集训,刘洋让我看了一下时间,突然发现,距离初赛就剩2天了......晚上,辅导班的老师对我们进行最后的培训,做了2套有道小图灵模拟题,但是做的不理想,很慌。......
  • 22级 20221314詹全晨 《计算机基础与程序设计》第三周学习总结
    作业信息班级的链接:https://edu.cnblogs.com/campus/besti/2022-2023-1-CFAP作业模板:https://www.cnblogs.com/rocedu/p/9577842.html#JXJC作业要求:https://www.cnblogs......
  • 2022 CSP-S 初赛
    CSP-S初赛游记2022年09月18日,CSP-S在下午14:30正式拉开帷幕,我在陕西西安参赛,考点:西工大附中初中部实验楼5层。声明:首先,我要说,陕西本来就是OI弱省,这一点,毋庸......
  • 2022-2023-1 20201324《信息安全系统设计与实现(上)》第10章
    目录0程序设计语言与shell脚本(1)一门程序设计语言有哪些必备的要素和技能(2)这些要素和技能在shell脚本中是如果呈现出来的1sh脚本2sh脚本与C程序3命令行参数4sh变量5sh......
  • 2022-2023-1 20221424俞鸿若劼 《计算机基础与程序设计》 第三周学习总结
    作业信息班级链接:https://edu.cnblogs.com/campus/besti/2022-2023-1-CFAP作业要求:https://www.cnblogs.com/rocedu/p/9577842.html#JXJC学习目标:数字分类与计数法、位......
  • 2022最新版 idea 好用的插件!!!!
    说明简单好用、增强功能1、AlibabaJavaCodingGuidelines2、SonarLint3、Translation4、BackgroundImagePlus+5、ChineseLanguagePack6、Translation7、KeyPromote......
  • 【题解】CF1311E Construct the Binary Tree
    题目链接-->Problem-E-Codeforces题目大意给定\(n\)和\(d\),你需要构造一棵\(n\)个点的二叉树满足所有点的深度之和恰好为\(d\)。\(2≤n,d≤5000\)。分析......
  • csp2022第一轮游记
    DAY-7?学校没买桶装水!我一时半会不去打水,真的渴。果不其然开始咳嗽了。DAY-1隔壁班同学主动申请停课了,我也跟来复习,这天主要的成果是把选择题错误控制到2-3题,顺便整理了......