CSP2024-30

news/2024/10/1 17:06:53

A

题意:将一个圆等分为 \(K\) 分,给出其中 \(n\) 个等分点的编号,\(x_i < x_{i + 1}\)

有向边 \(i \to j\) 存在,当且仅当 \(j\) 是距离 \(i\) 最大的点(不唯一),且与图中其他边无交点(端点不算)。

求图中最多有多少条边。\(3 \le K \le 10^9, 3 \le n \le \min(K, 10^5)\)

引理:不存在 \(A \to B,\ C \to D\),其中 \(A, B, C, D\) 互不相同。

作过 \(A\) 的直径 \(AA^\prime\),作 \(B\) 关于 \(AA^\prime\) 的对称点 \(B^\prime\)

  • 如果 \(C\)\(D\)\(\overset{\LARGE\frown}{BB^\prime}\) 上,由于大弧对大角 \(AC(D) > AB\)\(A \to B\) 的边不能存在,矛盾。
  • 如果 \(\overset{\LARGE\frown}{CD}\) 包含于 \(\overset{\LARGE\frown}{AB}\)\(CB > CD\),矛盾。
  • 如果 \(C\)\(\overset{\LARGE\frown}{AB}\)\(D\)\(\overset{\LARGE\frown}{AB^\prime}\),两边相交,不合法。

因此合法的状态只有两种:以某个点为中心的菊花状图;三条边首尾相连形成的等腰三角形。

注意两点的距离可以由对应弧长表示,也可以表示为跨过了多少整段:\(\min(\vert x_i - x_j\vert,\ K - \vert x_i - x_j\vert)\),这是个凸函数,可以二分找分界点。

求出离每个 \(i\) 距离最大的点集(最多两个),时间复杂度 \(O(n\log n)\)。(双指针能做到线性)

submission

B

题意:给出字符串 \(s, t\),文本串 \(T\) 的权值定义为 \(s\) 作为子序列在 \(T\) 出现的次数乘上 \(t\) 作为子序列在 \(T\) 出现的此次数。

给定 \(S\),求 \(S\) 所有子串的权值和。\(\vert S\vert \le 10^5,\ \vert s\vert, \vert t\vert \le 20\)

考虑没对子序列 \((s_1, s_2)\) 对答案的贡献(被多少区间包含),显然是第一个出现的位置乘上从最后位置开始的一个后缀长度。

\(f(i, j, k)\) 表示前 \(i\) 个字符,匹配到 \(s_1\) 的第 \(j\) 位,\(s_2\) 的第 \(k\) 位的开头位置和。

  • \(f(i, j, k) \gets [T_i = s_{1, j} = {s_{2, k}}]\times f(i -1, j - 1, k - 1)\)
  • \(f(i, j, k) \gets [T_i = s_{1, j}]\times f(i -1, j - 1, k)\)
  • \(f(i, j, k) \gets [T_i = s_{2, k}]\times f(i -1, j, k - 1)\)
  • \(f(i, 0, 1) \gets [T_i = s_{1, 1}] \times f(i - 1, 0, 0),\ f(i, 1, 0) \gets [T_i = s_{2, 1}] \times f(i - 1, 0, 0),\ f(i, 1, 1) \gets [T_i = s_{1, 1}= s_{2, 1}] \times f(i - 1, 0, 0)\)
  • \(f(i, j, k) \gets f(i -1, j, k)\)

考虑以 \(i\) 结尾的贡献,不能由第四种转移过来(因为对应方案 \(i\) 不是结尾),前四种转移过后的 \(f(i, \vert s_1\vert, \vert s_2\vert)\) 乘上 \(\vert T\vert - i + 1\)

submission

C

定义函数:

\[f(u, x, y) = \begin{cases} u - y & x = 1\\u& 1 < x \le y,\ x \perp y\\ -x \times y& x \ne 1,\ x \mid y\\ 0 & \text{otherwise} \end{cases} \]

给定长度为 \(n\) 的数组 \(a\),定义一段区间 \([l, r]\) 的优美度等于:

\[\sum_{i = 1}^{10^6}\sum_{j = l}^{r} f(u, i, a_j) \]

\(q\) 次询问,每次给出 \(l\) 和参数 \(u\),求 \(r \ge l\) 的最大优美度,以及对应最小的 \(r\)

数据范围:\(n, q \le 5 \times 10^5,\ 1 \le a_i \le 10^6,\ 1 \le u_i \le 1.8 \times 10^7\)

交换一下求和号:

\[\sum_{j = l}^{r}\sum_{i = 1}^{10^6} f(u, i, a_j) \]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.ryyt.cn/news/66839.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈,一经查实,立即删除!

相关文章

小白上手Arcgis—用于结合Netlogo、matlab等进行复杂网络操作

小白上手Arcgis(Netlogo复杂网络数据预处理) 1.前言废话:昨天突然想到可以写一下博客,用来记录一下自己的工作,主要是涉及复杂网络方面。情况简介:本人Arcgis小白,之前只是略微知道有这么个软件,以及知道怎么打开软件。学渣一个,而且不是学gis方向的,但由于工作需要,要…

windows10如何安装jdk8,并且配置java home环境?超详细!

前言 大家好,我是小徐啊。记得我刚学习Java的时候,我的老师第一步就是教我们如何安装jdk并且配置java环境。这应该算是学习Java的第一步吧。虽然这个安装过程对我来说已经不是非常难了,但是我知道,对于一些刚入门的小伙伴还是经常容易搞错的,所以,今天小徐就写一篇详细的…

安装小雅问题

如何卸载重装小雅、apt remove xiaoya docker stop 01ec8396b2c529819bb7c95091a88a9af6999c042bcb7ab57662837c97dca5cd docker rm 01ec8396b2c529819bb7c95091a88a9af6999c042bcb7ab57662837c97dca5cdsystemctl start cpolar 开启cplpr systemctl status cpolar

leetcode24 两两交换链表中的节点(swap-nodes-in-pairs)

### 题目描述: 给你一个链表,两两交换其中相邻的节点,并返回交换后链表的头节点。你必须在不修改节点内部的值的情况下完成本题(即,只能进行节点交换)。 示例 1:输入:head = [1,2,3,4] 输出:[2,1,4,3]示例 2: 输入:head = [] 输出:[]示例 3: 输入:head = [1] 输出…

第一章:Borel测度

第1章 Borel测度 在正式讨论我们的内容之前我们先做几点说明 1.我们只讨论\(\mathbb{R}^n\) 上的测度,因此如果不作特别说明,我们均认为测度和集合为于\(\mathbb{R}^n\) 中: 2.我们不特别区分外测度和测度,因为将外测度限制在可测集上就是可测集上的测度: 3.我们默认读者已…

TypeScript在vue中的使用-----事件类型的获取

当我们要对事件定义类型。一种是通过console.log(e)来看事件的类型。另外一种是@事件名的时候,将$event写好,鼠标放上去看事件类型。再讲$event删除。 如下: 然后我们定义函数的时候就可以指定事件类型了const clickMi = (e:MouseEvent)=>{console.log(e.pageX, e.pageY…

信息学奥赛复赛复习08-CSP-J2020-03表达式前置知识点-后缀表达式、栈、字符读取

PDF文档公众号回复关键字:202410011 P1449 后缀表达式 [题目描述] 所谓后缀表达式是指这样的一个表达式:式中不再引用括号,运算符号放在两个运算对象之后,所有计算按运算符号出现的顺序,严格地由左而右新进行(不用考虑运算符的优先级) 本题中运算符仅包含 + - * / 。保证…

IDEA如何查看已经安装的插件并删除

前言 我们在使用IDEA开发时,经常需要安装一些插件来帮助我们高效快速的处理问题,可以说很实用。 不过有时候,我们不想使用某个插件了,或者某个插件突然不好用了,想要先删除下再安装,那么我们应该怎么删除我们已经安装的插件呢? 如何删除插件 首先,我们点击【File】->…