首页 > 其他分享 >寒假训练总结

寒假训练总结

时间:2024-06-20 16:21:46浏览次数:20  
标签:总结 那么 题目 log 训练 solution 寒假 集合 考虑

2023.1.19

T3

题目大意

给定一棵树,边有黑白两种颜色,初始边都是黑色

有两种操作

  1. 将u到v路径上的边颜色反转
  2. 询问u只经过黑边能走到几个点

solution

可以想一下链的部分分,用线段树维护边的颜色,然后在线段树上二分(或者二分套线段树)来找到点u经过黑边走到的区间

拓展到树上,考虑树链剖分,每个节点维护其轻儿子和本身组成的黑色连通块大小(就是只经过黑边能走到的点数)\(f_i\)

然后查询就比较简单,从点u向上跳重链,保证路径上都是黑边,然后找到第一个不符合的重链和对应的位置,然后对于这个点和重链做链的部分。不过每个点的贡献变成\(f_i\),还要再打个线段树

那么如何修改,先考虑差分,修改u到根的边,那么维护边的线段树要维护反转,维护 \(f\) 的线段树在轻边处要修改。修改时先从上到下黑变白,然后颜色反转,最后从下到上白边黑(这个顺序时保证减去的原来的,加上的是新的),修改时还要调用二分的那个部分

所以时间复杂度是\(O(q\log^2 n)\)

2023.1.22

T1

题目大意

给定一棵树,树上每个点有权值\(a_i\),有以下两种操作:

  1. 让第x层的节点都变成其子树中的最小值
  2. 让第x层的节点都变成其子树中的最大值

问最后根节点的权值

solution

这道题有启发性的部分分是 \(a_i=0/1\) ,但是这档分可以用水法过掉,就没有仔细想,亏...

首先这道题的第一想法是把每一层的状态压起来,叶子节点的权值不变。对于\(a_i=0/1\),进行简单的分讨:

  1. 最后一次对根的修改是取最小值
  2. 最后一次对根的修改是取最大值,与上面类似

那么若存在 \(a_i>1\) ,应该这么做呢?

不难发现,如何我们对于第一种情况,我们把 \(a_i<=mid\) 当成1,其他当成0,然后做一遍链的部分,若可以答案为1,则答案一定小于n,这可以二分

情况二类似,时间复杂度\(n\log^2n\)

T2

题目大意

n个有标号的数放进k个有标号的集合,要求每个数都在一个集合,每个集合至少有一个数

定义一个集合的贡献为集合中的全部数的按位与和,一种分配方案的贡献为k个集合的贡献和

求全部分配方案中,贡献最大的的值和数量

solution

首先可以想到从高位往低位做,那么我们就可以贪心,因为高位一定能选就选,否则一定不会更优

令还剩下n个数,k个集合,有c个数的第w位为p

  • 如果 \(n=c\) ,我们给 \(ans1\) 累加 \(k2^p\)
  • 否则如果 \(c\le k-1\) ,意味着c个1我们都要放到不同集合,我们给 \(ans1\) 累加 \(c2^p\) ,给 \(ans2\) 乘上 \(\binom{k}{c}c!\) ,然后把这c个数删掉,\(k=k-c\)
  • 否则,我们就把这位为0的合并起来,给 \(ans1\) 累加 \((k-1)2^p\)

最后我们发现,可能剩下n个数,k个集合,那么就把答案乘上 \(S(n,k)k!\)

2024.1.23

T1

考场上差不多想到了

题目大意

定义 \(f(a[1,2,...,n],S)\) 表示把集合 \(S\) 插入序列 \(a\) 中,最小的逆序对数

给定 \(n,m\) 和 \(p\) 序列,有个序列 \(b\) ,满足 \(b_i\in [1,n+m]\cup\Z\) ,\(b_i\) 互不相同且为第 \(p_i\) 小的

问所有符合要求的序列 \(b\) 的 \(f(b,\{1,2,...,n+m\}-\{b_1,b_2,...b_n\})\) 的和

solution

首先用历史版本最小值求出,分别在这 \(n+1\) 个间隙中插入数字最小增加的逆序对数

然后发现答案是新增加的逆序对+方案数 \(\times\) 原逆序对数

题目就变成了有 \(m\) 个求,\(n+1\) 个位置,在 \(i\) 个位置放 \(x\) 个球的贡献为 \(xw_i\),问所有放置方案的贡献和

发现每个位置是等价的,而且都恰好贡献了 \(\binom{n+m}{n+1}\) 次

T2

题目大意

有 \(n\) 只老鼠,位置和家分别在 \(x_i,y_i\) ,我们在其中建造 \(k\) 个中转站 \(z_1,z_2,...,z_k\),代价为 \(\sum_{i=1}^nmin_{j=1}^k|x_i-z_j|+|y_i-z_j|\)

问 \(k=1,2,...,m\) 的答案

solution

首先考虑贪心,我们按照 \(x_i+y_i\) 排序,那么一个中转站一定管理一段区间

那么知道了一段区间,如何算贡献呢?继续贪心,中转站应该建在这段区间的 \(x,y\) 的中位数上

那么我们就可以打一个时间复杂度为 \(O(n^3m)\) 的暴力(可以拿50pts)

考虑先优化计算区间的一个 \(n\) ,这里可以用主席树解决

然后观察到决策单调性(区间越长,增速越大),然后用分治再优化掉一个转移的 \(n\)

最后的时间复杂度为 \(O(nm\log^2n)\)

2024.1.25

没得去清北营,滚回来打A组,题目一般,可以乱搞

T3

唯一一道清新的构造题

题目大意

有 \(m\) 条电线, \(n\) 条导线

依次给出 \(n\) 条导线,连接着 \(x,y\) 两条电线,设原来两条线的通电状态为 \(s_x,s_y\) 。那么可以让两条的状态变成 \(s_x|s_y,0\) 或 \(0,s_x,s_y\)

初始的通电状态都是 \(s_i=1\) ,要求最后的通电电线数量不小于 \(\lfloor\frac m2\rfloor\) ,问导线方向

solution

可以想到把电线两两分组(奇数就单独一组),要求每组内至少有一条电线是通电的,且可以通过改变导线方向决定是哪个通电

顺推分组,若有导线 \((x,y)\) ,有两组 \((x,u),(y,v)\) 电线,那么调整成 \((x,y),(u,v)\) 也满足

同理:有两组 \((x,u),(y)\) ,可以调整成 \((x,y),(u)\)

然后倒推,先给每组电线钦定一个通电状态,然后撤回导线操作,判断是否合法,输出导线方向

2024.1.26

还是A组,题目比较水,记录一点题

T3

矩乘好题,是没做过的类型

题目大意

给定 \(n,k,a,b\)

你现在位于 \((1,\frac k2)\) ,每次移动只能是从 \((x,y)\) 到$ (x+1,y)(x+1,y-1)(x+1,y+1)$,目 \(y\) 不能超 \([1,k]\) 的范围,你的目标是到 \((n,\frac k2)\)

在 \([2,n-1]\) 中,会随机出现一个障碍 \([1,a]\cup[b,k]\)

求期望可行的行路径数量 \(\mod 10^9+7\)

solution

我们定义正常的转移矩阵为\(A\),障碍的转移为 \(B\) ,那么答案就

\[\frac{\sum_{i=2}^{n-1}A^{i-1}BA^{n-i}}{n-2} \]

无法直接计算,我们考虑定义

\[X_i=A^i,Y_i=\sum_{j=2}^iA^{j-1}BA^{i-j} \]

于是就有转移:

\[X_i=X_{i-1}A,Y_i=Y_{i-1}A+X_{i-1}B \]

于是我们把 \(Y\) 接在 \(X\) 的右下角即可转移,转移矩阵为:

最后答案为\(Y_{n-1}A\)

2024.1.29

比赛时一直在摸鱼,最后两个小时水了一下提答题,结果水了70

T1

题目大意

构造一个有 \(2n\) 个点的二分图,在左边选定点的集合 \(S\) ,定义 \(F(S)\) 表示与 \(S\) 中的点有连边的点的集合,若对于所有的集合 \(S\) ,满足 \(|F(S)|<|S|\) 的恰好有k个

solution

考虑 \(i\) 连边的集合为 \(s_i\) ,那么要求 \(s_i\subseteq s_{i+1}\),令 \(d_i=|s_{i+1}|-|s_i|\)

那么考虑

2024.2.1

考场切了T1,T2胡了一个贪心,挂了,还挂了7分的部分分

T2

ds好题,和联考的lis很像,但要难

题目大意

有 \(n\) 个二元组 \((x,y)\) ,若满足 \(x_i\le x_j\) ,那么可以获得 \(y_j-y_i\) 的贡献,并把它们删掉

问至多取 \(k\) 对二元组,问最大贡献。对 \(k=1\sim\lfloor\frac n2\rfloor\) 求出答案

solution

先按照 \(x\) 为第一关键字, \(y\) 为第二关键字排序

考虑费用流建模,暴力建模:

  1. \(i<j\) ,连费用 \(y_j-y_i\) ,流量为 \(1\) 的边
  2. 原点向 \(i\) 和 \(i\) 向汇点连流量为 \(1\) ,费用为 \(0\) 的边

再考虑差分优化一下

  • 把上面第一种边改为,对于 \(i\) 到 \(i+1\) 连费用为 \(y_{i+1}-y_i\) ,流量为 \(1\) 的边

那么我们找一条可行流,就等价于找一个最大子段和

找一条退流,就等价于在反边中找最大子段和

然后对于选择的两个端点,不能再作为起点或终点

正的流量,考虑进行区间+1操作,若一段中都有流量,即最小值不为0,则可以退流

考虑如何维护,维护三个字段和信息,分别为正边的,反边的,反边且不能流最小值位置的

push up的时候,前两个可以直接合并,最后一个则判断最小值在哪边,分3种情况合并

再维护一个区间+1和-1

关于删除端点,有点细节,因为我们的节点维护的是边的信息,所以假如我们删去的是 \(l,r\) :

  1. l删去后缀,l-1删去前缀
  2. r+1删去后缀,l删去前缀

然后每次选最优的区间即可,若最小值等于0,就在第一和第三个中取最大值,否则在第一和第二中取

若某次的增量小于0,就不选


第二期...

2024.2.16

开始联考

2024.2.17

用自己的题

number

对于一个值域和定义域均为 \(U\) 的函数 \(f(x)\),定义其将所有 \(i=1,2,\cdots,n\) 由 \(i\) 向 \(f(i)\) 连边形成的内向基环森林为 \(T(f)\)。

考虑对于某个 \(g(x)\),\(T(g^{n-1})\) 具有怎样的特征,将 \(T(g^{n-1})\) 中 \(i\) 的出边视作在 \(T(g)\) 中从 \(i\) 点沿出边方向走 \(n-1\) 步的终点:对于 \(T(g)\) 中在环上的点,在 \(T(g^{n-1})\) 中其依然在环上;对于 \(T(g)\) 中不在环上的点,在 \(T(g^{n-1})\) 中其依然不在环上,但由于 \(n-1\) 充分大,其在 \(T(g^{n-1})\) 中与所在基环树上的环的距离必然为 \(1\)。

首先忽略 \(T(g^{n-1})\) 中不在环上的点,容易发现如果有 \(i\) 个点在环上,那么环外的点的方案数即为 \(i^{n-i}\)(这是因为对于每一个环外点的连接方案,都容易反向构造出 \(T(g)\)),则我们只需要对于所有 \(i=1,2,\cdots,n\) 计算出有 \(i\) 个点在环上的方案数 \(h_i\)。

接下来只需要考虑环长的限制,若 \(T(g)\) 中有一个长度为 \(d\) 的环,那么在 \(T(g^{n-1})\) 中其会被分裂为 \(\gcd(d,n-1)\) 个长度为 \(\dfrac{d}{\gcd(d,n-1)}\) 的环,记 \(v_d=\dfrac{d}{\gcd(d,n-1)}\),对于每个 \(i\),记所有 \(v_d=i\) 的 \(d\) 形成的集合为 \(S_i\),那么长度为 \(i\) 的出现次数 \(c\) 的限制即为:\(S_i\) 内元素除 \(i\) 后进行完全背包,\(c\) 需要能被若干可重物品的和表出,这里做完全背包的复杂度是总体 \(O(n^2)\) 的。

那么,我们已经刻画了对于所有环长及其出现次数的限制,可以使用一个背包计算答案,每次枚举新加入的环长使用了多少个,使用组合数计算贡献。注意到对于长度为 \(i\) 的环,其至多使用 \(O(\dfrac{n}{i})\) 个,那么由调和级数,总复杂度即为 \(O(n\sum\limits_{i=1}^n\dfrac{n}{i})=O(n^2\log n)\)。

yoimiya

考虑一个串 \(a\),考虑刻画出所有的 \(i,k\) 使得 \(a[i,i+k-1]=a[i+k, i+2k-1]\)。

枚举 \(k\),设 \(b_i=[a_i==a_{i+k}]\),那么我们只需要找到 \(b\) 中所有长度 \(\ge k\) 的连续段。

注意到这样的连续段的段数不超过 \(\lfloor n/k\rfloor\),考虑一段一段找。发现长度 \(\ge k\) 就至少需要经过 \(k,2k,\cdots\) 这些位置中的一个,考虑枚举 \(x=ik\),算出经过 \(x\) 的极长连续段长度。那么只需要查询 \([1,x],[1,x+k]\) 的最长公共后缀与 \([x,n],[x+k,n]\) 的最长公共前缀即可。SA 配合 ST 表容易做到 \(O(n\log n)\)。

现在我们找到了一个极长的连续段 \([L,R]\),那么相当于对每个 \(i=L,L+1,\cdots,R-k\),连边 \((i,i+k)\)。然后对每个连通块,把他的 \(L\) 限制取 max,\(R\) 限制取 min,每个连通块的 \((R-L+1)\) 的乘积就是答案。

注意到合并只会发生 \(O(n)\) 次,考虑快速找到所有需要合并的位置。考虑建 \(O(n\log n)\) 个虚点,\((i,j)\) 代表 \([i,i+2^j-1]\) 这个区间整体的合并情况,然后用并查集维护每一层所有点的连通情况。

换言之,如果 \((x,j),(y,j)\) 已经连通,代表着我们已经确定 \(b[x,x+2^j-1]=b[y,y+2^j-1]\)。

那么每次区间连边我们首先拆成两个长为 \(2^k\) 的区间连边,然后自顶向下递归,即可在 \(O(\alpha(n)\times\log n)\) 的时间内找到一个未被合并的位置。然后并查集在合并的时候处理一下对答案的影响即可。

由调和级数可知外层的连边次数不超过 \(O(n\log n)\);另一方面在并查集上面每次连边必然会少一个连通块,而一共只有 \(O(n\log n)\) 个点,因此复杂度为 \(O(n\alpha(n)\times \log n)\)。

标签:总结,那么,题目,log,训练,solution,寒假,集合,考虑
From: https://www.cnblogs.com/zhy114514/p/18258903

相关文章

  • 省选训练总结
    目录2024.2.19T1题目大意solutionT2题目大意solution2024.2.20T1T22023.2.22T1题目大意solution2023.2.23T1题目大意solutionT2题目大意solution2024.2.26T1题目大意solutionT2题目大意solutionT3题目大意solution2024.2.27T1题目大意solutionT3题目大意solution2024.2.28补题2024......
  • MySQL 常用函数总结
    MySQL提供了丰富的内置函数,用于在查询中进行各种计算、字符串处理、日期和时间操作等。这些函数可以帮助我们更有效地从数据库中检索和处理数据。下面将总结一些MySQL中常用的函数及其用法。1.数值函数1.1ROUND()ROUND()函数用于对数值进行四舍五入操作。SELECTR......
  • 关于后端幂等性问题分析与总结
    后端幂等性(Idempotency)是指对系统执行一次操作或多次执行相同的操作,其结果始终如一。在分布式系统和API设计中,这是一个关键概念,因为它能保证用户无论请求被路由到哪个节点,多次执行相同的请求都不会导致副作用的累积,从而提升系统的可靠性和一致性。问题分析与总结:定义:检查一......
  • 【算法与设计】期末总结
    文章目录第一章概述算法与程序时间复杂性求上界第二章递归与分治双递归函数——Ackerman函数分治策略大整数乘法两位×两位四位x四位三位x三位两位x六位第三章动态规划矩阵连乘基本要素最优子结构子问题重叠备忘录第四章贪心算法活动安排问题基本要素贪心选......
  • HTTP详细总结
    概念HyperTextTransferProtocol,超文本传输协议,规定了浏览器和服务器之间数据传输的规则。特点基于TCP协议:面向连接,安全TCP是一种面向连接的(建立连接之前是需要经过三次握手)、可靠的、基于字节流的传输层通信协议,在数据传输方面更安全。基于请求-响应模型的:一次请......
  • 项目总结
    项目总结:关爱老人项目引言本文档旨在总结关爱老人项目的开发过程和取得的成果。项目从需求分析、设计到实现,以及后续的测试和发布,全面回顾并分析了项目中的关键步骤和决策过程。总体设计项目采用了B/S架构,主要涉及运动打卡和点菜系统两大功能模块。运动打卡系统实现了计时......
  • JavaScript基础部分知识点总结(Part3)
    函数的概念1.函数的概念在JS里面,可能会定义非常多的相同代码或者功能相似的代码,这些代码可能需要大量重复使用。虽然for循环语句也能实现一些简单的重复操作,但是比较具有局限性,此时我们就可以使用JS中的函数。函数:就是封装了一段可被重复调用执行的代码块。通过此代码块可......
  • Windows安全加固总结(非常详细)零基础入门到精通,收藏这一篇就够了
    为了达到安全的目的,一般来说我们需要关注操作系统的八个方面:补丁管理>账号漏洞>授权管理>服务管理>功能优化>文件管理>远程访问控制>日志审计其中:补丁管理使用最新版的补丁,避免使系统存在已知的漏洞,从而被攻击者利用。账号口令梳理出系统中正在使......
  • 基于稀疏矩阵方法的剪枝压缩模型方案总结
    1.简介1.1目的在过去的一段时间里,对基于剪枝的模型压缩的算法进行了一系列的实现和实验,特别有引入的稀疏矩阵的方法实现了对模型大小的压缩,以及在部分环节中实现了模型前向算法的加速效果,但是总体上模型加速效果不理想。所以本文档针对这些实验结果进行分析和总结。1.2范围......
  • Beta版总结会议
    项目总结项目名称:冀网社区聘项目概述:本项目旨在开发一个校园兼职招聘系统,为学生提供便捷的兼职发布、搜索功能,以及社交交流和广告展示等服务。项目由李健龙领导,郑盾作为核心开发人员之一,团队努力推动各项功能的设计、开发和上线工作。项目成果与问题:在项目开发的过程中,团队取......