07 2023 档案
0730小马拉松 题解
摘要:[T358782 阶乘](https://www.luogu.com.cn/problem/T358782?contestId=121340) 数学。 测试点 :`long long` 暴力阶乘。预期 30 分。 测试点 :暴力试除,找出因子 的个数。预期
题解 P9474 [yLOI2022] 长安幻世绘
摘要:看到极差,不难想到双指针。 显然,如果 的位置都被覆盖,那么其中最多可以选 个数。 我们先将所有数离散化,排序,双指针卡取值范围。 `set` 里面存 `pair` 类型变量,表示覆盖的区间。 每次将值为 的数的位置
BJ省选前训练记录+游记
摘要:3.13 Day-18: [ [ARC158A] +3 +5 +7 ](https://www.luogu.com.cn/problem/AT_arc158_a) [ [ARC158B] Sum-Product Ratio ](https://www.luogu.com.cn/problem/AT_
题目总结
摘要:[P1758 [NOI2009] 管道取珠](https://www.luogu.com.cn/problem/P1758) 看见方案数平方,考虑两个人分别取,两两匹配。 [P1912 [NOI2009] 诗人小G](https://www.luogu.com.cn/problem/P1912) 决
NOI春季测试前模拟赛题解
摘要:[ T312819 命题工作 ](https://www.luogu.com.cn/problem/T312819) 直接容斥。 总方案 - 一题出现四次 - 一题出现三次 - 一题出现两次。 一题出现两次的情况略有不同,注意考虑周全。 复杂度 。 [code](https://www.
省选计划 (第七周)
摘要:练了好久 CF&AT 的题,现在要回归省选计划了! #### 知识回顾 - 巩固:二维树状数组 - 深入了解:可持久化数据结构 - 简单了解/没学明白: #### 练题 [P3567 [POI2014]KUR-Couriers](https://www.luogu.com.cn/problem/P3
省选计划(第六周)
摘要:### 知识回顾 - 巩固:Lucas,网络流,二分图 - 深入研究:背包DP,树形DP,区间DP,状压DP。 - 简单了解/没学明白:博弈论,插头DP ### 练题 [Working routine](https://www.luogu.com.cn/problem/CF706E) 读完题后以为矩
省选计划(第五周)
摘要:### 知识回顾 - 巩固:线段树,贪心 - 深入研究:数论,容斥,除法分块,根号分治 - 简单了解:lucas,prufer序列,莫比乌斯反演 ### 练题 [P2606 [ZJOI2010]排列计数](https://www.luogu.com.cn/problem/P2606) 可以发现这符合
省选计划(第四周)
摘要:# 第四周 ### 知识回顾 - 巩固:2-SAT - 深入研究:概率与期望 - 简单了解/没学明白: ### 练题 [P3825 [NOI2017] 游戏](https://www.luogu.com.cn/problem/P3825) 很麻烦的 2-SAT。 如果没有 x,就是个传统的问题。 然
省选计划(第三周)
摘要:### 知识回顾: - 巩固:概率DP,错排,组合数 - 深入研究:组合数,后缀数组,tarjan,2-SAT - 简单了解/没学明白: ### 练题: [[ABC280F] Pay or Receive](https://www.luogu.com.cn/problem/AT_abc280_f)
省选计划(第二周)
摘要:### 知识回顾: - 巩固:二分,倍增,优化DP,莫队,分数规划,网络流,二分图,贪心,set/map,KMP - 深入研究:分治(线段树分治),后缀数组,费用流 - 简单了解/没学明白:线性基,边分治,数位DP,博弈论 ### 练题: [[SCOI2015]国旗计划](https://www.l
省选计划(第一周)
摘要:### 知识回顾: - 巩固:生成树,DP,分层图,简单数论,线段树。 - 深入研究:网络流。 - 简单了解/没学明白:FFT。 ### 练题: [P6144 [USACO20FEB]Help Yourself P](https://www.luogu.com.cn/problem/P6144) 定
ARC154
摘要:[[ARC154A] Swap Digit](https://www.luogu.com.cn/problem/AT_arc154_a) 和一定差小积大,竟可能的使两个数差大即可。 复杂度 。 ```cpp #include using namespace std; typedef lo
CF1777
摘要:[Everybody Likes Good Arrays!](https://www.luogu.com.cn/problem/CF1777A) 简单题。 因为偶乘偶为偶,奇乘奇为奇,所以直接找有多少个奇偶性相同的块即可。 最后修改次数就是 。 复杂度 。 ```cpp #
CF1781
摘要:tourist 场 Orz。 [Parallel Projection](https://www.luogu.com.cn/problem/CF1781A) 分类讨论题。 1. 将 坐标对齐,然后前后绕。 2. 将 坐标对齐,然后左右绕。 两种情况取最小值即可。 复杂度
CF1792
摘要:[GamingForces](https://www.luogu.com.cn/problem/CF1792A) 贪心,从小到大排序。 对于当前怪物,如果血量大于 ,则直接杀死,否则和下一个怪物各扣一滴血。 复杂度 。 ```cpp #include using nam
CF1783
摘要:[Make it Beautiful](https://www.luogu.com.cn/problem/CF1783A) 构造题。 如果元素互不相同,我们可以降序排列。 如果有相同元素的话,就多构造几个降序排列拼在一起,可以证明符合条件。 复杂度 。 [Matrix of Differ
ABC286
摘要:[[ABC286C] Rotate and Palindrome](https://www.luogu.com.cn/problem/AT_abc286_c) 容易发现两种操作互不干扰,所以考虑枚举换位操作个数,再计算出相应的替换操作个数,最后取最小值即可。 复杂度 。 [[ABC2
ABC285
摘要:[[ABC285D] Change Usernames](https://www.luogu.com.cn/problem/AT_abc285_d) 依据题意直接连边,判断有没有环即可。 复杂度 [[ABC285E] Work or Rest](https://www.luogu.co
ARC153
摘要:[[ARC153A] AABCDDEFE](https://www.luogu.com.cn/problem/AT_arc153_a) 第一眼看上去让人以为是数位 DP,但看一眼样例 2 就知道直接枚举就行了。 六层循环暴力枚举。 复杂度 。 [[ARC153B] Grid Rot
ABC284
摘要:[[ABC284D] Happy New Year 2023](https://www.luogu.com.cn/problem/AT_abc284_d) 暴力肯定不行,尝试简单讨论一下。 1. 如果 ,那么 ,那么 ,因
CF1775
摘要:[A1&A2.Gardener and the Capybaras (hard version)](https://www.luogu.com.cn/problem/CF1775A2) 超级诈骗题。 直接 枚举肯定不行。 我们考虑两种情况: 1. B 最小:直接看最小的字符是否在区
题解 P9437『XYGOI round1』一棵树
摘要:换根 DP。 本蒟蒻最初没想到换根,把自己写自闭了... 定义 为子树 中的每个结点走到 的贡献和, 为大于 的最小的 的幂次方数, 为 。 转移方程为:$f_u
题解 P4183 [USACO18JAN] Cow at Large P
摘要:带有小 trick 的点分治。 建议先做完 [弱化版](https://www.luogu.com.cn/problem/P4186) 再看。 假如奶牛在 ,那么所需的最少农夫数为 $\sum\limits_{v\in son(u)}[dis(u,v)\ge g_v][dis(u,fa_v)
题解 P2137 Gty的妹子树
摘要:神奇的分块。 假如没有 操作,我们可以直接用主席树解决。 我们考虑将询问分块,每遍历完一块就将这一块内出现的所有修改更新。如果在块内,就把当前块之前的所有修改暴力算,当然只有修改的节点在询问的节点的子树内才会发生。 具体的来说,我们可以用分块维护 dfs 序,并将块内的元素排序,询问 $O(
题解 P3345 [ZJOI2015] 幻想乡战略游戏
摘要:点分树。 本题的核心问题在于不好直接确定补给站的位置。 但是仔细思考后我们发现,对于当前节点,如果存在一个儿子的答案比它优,那么补给站一定在那个儿子的子树中。 增量为 。当 优于 时,。
题解 P6329【模板】点分树 | 震波
摘要:点分树模板题。是个神奇的算法。 点分树就是将分治重心按照层级连边,每个节点父亲的联通块都包含了当前节点的联通块,且高度为 。可以解决不考虑树的形态的多次询问带修改的问题。 对于这道题,我们可以在点分树的每个节点上记录两棵树状数组,分别与当前节点距离为 的节点的权值和,以及与当
题解 P7215 [JOISC2020] 首都
摘要:点分治。 考虑当前的分治重心的城市被完全联通。 这可以用队列接解决。每次放入一种城市,就把那些城镇的父亲加入队列,如果存在城镇不在当前分治重心的联通块内,那么说明必定存在另一个分治重心能算到它,直接退出即可。 剩下的和模板没有任何区别。 复杂度 。 code: ```cpp
题解 P3806 【模板】点分治1
摘要:点分治模板题。 点分治适合处理大规模的树上路径信息问题 暴力做法:dfs 每个点 ,算出其子树内每个点到 的距离,统计经过 的所有路径,复杂度 。 容易发现,复杂度和子树大小有关。 对于当前子树,我们可以求出其重心,计算经过重心的所有路径,删掉重心,递归每个联通
题解 P5384 [Cnoi2019] 雪松果树
摘要:这题有紫?? 对于询问节点 ,倍增地跳到它的 级祖先,求其子树内有多少深度为 的节点。 我们考虑把询问离线,再通过 dfs 序把树拍平,然后扫一遍直接求就行了。 复杂度 。 code: ```cpp #include using namespac
题解 P4074 [WC2013] 糖果公园
摘要:树上带修莫队。 **带修莫队复杂度分析:** 带修莫队比普通莫队多了一个时间戳,排序的时候先排左端点,再排右端点,如果左右端点所在块对应相等,则按时间戳排序。 设区间长度为 ,询问数为 ,修改数为 ,块长为 。 我们分别考虑时间戳、左端点和右端点的移动次数。 时间戳:对于每一
题解 CF840B Leha and another game about graph
摘要:构造题。 首先判断无解。每选一条边贡献两个度数,所以如果没有 的点,且度数和为奇数,那么无解。 接下来考虑构造。我们考虑从图中扣下来一棵树(dfs 树),如果度数为奇数,令 的点为根,否则随便选一个。 定义 表示第 个节点是否需要与父亲连边, 表示不用
题解 CF900D Unusual Sequences
摘要:如果 不是 的倍数,答案为 。 否则计算有多少种数列满足所有数 为 且和为 。 定义 表示和为 且 为 的数列的数量。 显然有如下等式: $$2^{x-1}=\sum\limits_{d\
题解 CF1106E Lunar New Year and Red Envelopes
摘要:小清新 DP 题。 定义 表示在时刻 ,干扰了 次,最小贡献。 定义 表示在时刻 会收集哪个红包。 那么转移方程为: $$f_{i+1,j+1}=\m
题解 CF1202C You Are Given a WASD-string
摘要:不错的题,需要点思维和码力。 容易发现,左右和上下互不影响,可以分开处理,这里以左右举例。 定义向左走一格 ,向右走一格 ,求个前缀和找到最大值和最小值,和出现最值的最早时间与最晚时间。定义为 。 只有当我们放了一个 A 或 D 使得所有最大值 且最小
题解 CF156C Cipher
摘要:容易发现,如果把字母表映射到 上,那么无论怎么操作总和都不变。 于是可已将问题转化为:有多少种长度为 的序列,满足每个元素在 之间,总和为 。 定义 表示处理到第 个元素,总和为 的合法方案数。 转移方程为 $
题解 CF1265E Beautiful Mirrors
摘要:期望 DP。 定义 表示第 个镜子照成功的期望天数, 为第 天成功的概率, 为第 天失败的概率。 根据题意容易列出方程: 移项得: $$
题解 CF930C Teodor is not a liar!
摘要:好题啊好题。 定义 为有多少个区间包含 。 拍脑袋一想,当且仅当存在顺序的三个坐标 满足 且 $a_j using namespace std; const int N=1e5+5; int n,m,a[N],f[N],g[N],c[N];
题解 CF213C Relay Race
摘要:考虑朴素 DP。定义 表示两个人分别在 时获得的最大收益。复杂度 ,不行。 我们换种方法,定义 表示两人同时走了 步,分别向右走了 步。显然如果向右的步数确定了,向下的也确
题解 CF980D Perfect Groups
摘要:有个显然的小 trick:如果两个数相乘为平方数,那么消去平方因子后这两个数相等。 于是我们可以暴力枚举,每出现一个新数就加一,用 unordered_map 维护,然后就 T 了。 考虑优化。我们对于每个数预处理出上一个与它相等的数的位置。这样每次枚举的时候只需要看 是否小于左边界
题解 CF1271D Portals
摘要:贪心+DP。 对于一个点,后选显然比先选好,也就是说每个点都对应了唯一一个来源。 于是我们可以把每个点所能回溯到的点的收益值从大到小排序,贪心地选前缀。 定义 表示考虑了前 个点,剩下 个人,最大收益。 转移方程和 背包的一样。 $$f_{i,j}=f_
题解 CF1379F2 Chess Strikes Back (hard version)
摘要:数据结构之小清新思维题。 容易想到把 棋盘中每个 的部分压缩,其中必须含有恰好一个棋子。 对于每个 分两种情况讨论(可能同时具备或不具备以下两种): 1. 左上角不能用,记为 。 2. 右下角不能用,记为 。 然后
题解 CF1313D Happy New Year
摘要:带有小 trick 的 DP,长知识了。 很大,需要离散化。 为了方便,采用扫描线的方式,不对其进行实际意义上的离散,而是对于第 个区间 ,插入 两个 pair,最后排个序。这样相邻两个 pair 之间的部分就缩成了一个点。 同时我们还
题解 CF799D Field expansion
摘要:有趣的 BFS 题。 首先发现,一个数最多乘 次后超过上限,所以我们可以考虑 BFS。 将 数组元素从大到小排序,定义 表示当前长为 ,宽为 ,操作了 次。每次操作将两个数中没超过上限的乘上 。 由于可以旋转 $90^\ci
题解 CF1338B Edge Weight Assignment
摘要:小清新思维题。 先找一个不是叶子的节点,令它为根。 那么当且仅当,对于每一个非叶子节点,它包含的叶子节点到它的异或路径相等时,才满足题目要求。 考虑第一问,显然如果每个叶子的深度奇偶性相同,可以全填一样的数字,答案为 。反之为 (可以在一条链上试一试)。 对于第二问,定义 表
题解 CF985E Pencils and Boxes
摘要:贪心+DP。 先从小到大排序。 定义 表示序列 能否分组。 转移为 。 右区间可以直接算出来,左区间可以二分或根据单调性弄个指针。 定义
题解 CF417D Cunning Gena
摘要:,状压 DP。 首先可以根据每个人的 从小到大排序。 定义 表示考虑到第 个人,完成了 状态的题目,不考虑显示器所需的最小价格。 转移显然为 。 最终答案为 $ans=\m
题解 P6091 【模板】原根
摘要:题解太高深,自己整理一份。 **阶的定义:** 若 ,则使 的最小的 称为 关于模 的阶,记为 。 **阶的性质:** 根据欧拉定理,$a^{\varphi(m
题解 P3803 【模板】多项式乘法(FFT)
摘要:感觉题解区不是写的太高深,就是写的太高深。所以给初中、小学和幼儿园的萌新准备一篇简单易懂的良心题解~ 前置知识 一、多项式的系数表示法和点值表示法。 系数:\((a_0,a_1,a_2...a_{n-2},a_{
题解 P8338 [AHOI2022] 排列
摘要:恶心题。 每次操作,相当与把第 个数置换到 ,于是可以连边。 因为 和 互不相同,所以对于每一个点,有且仅有一条出边和一条入边,即若干个简单环。 那么最少操作 $\operatorname{lcm}(a_1,a_2,a_3...a_{x-2},a_{x-1},a
题解 CF840C On the Bench
摘要:[更好的阅读体验](https://www.luogu.com.cn/blog/leleleeee/ti-xie-cf840c-on-the-bench) 这是一篇简洁易懂的良心题解,提供了多种做法。 对于两个数 ,定义 。如果
题解 P5339 [TJOI2019]唱、跳、rap和篮球
摘要:组合容斥问题。 定义 为至少有 组人会讨论的方案数。 那么最终答案就为 。 在 个人中选 组人讨论的方案数为 $\dbin
题解 P3248 [HNOI2016]树
摘要:有意思的题,927ms 拿下最优解。 点数最多 个,没法暴力拼接,考虑简化大树。 每次拼接,我们记录 , 和 所在大树的根节点 。然后连两条边: 和 。本质上相当于把每次接上来的子树缩成一个点。 这样大树的点数最
题解 CF1777D Score of a Tree
摘要:[Score of a Tree](https://www.luogu.com.cn/problem/CF1777D) 思维题。 我们考虑一个点 在所有时刻内的点权为多少。 可以发现,假如 的深度为 ,那么 时刻时它的权值为其子树内所有深度为 的点的初始权值异或
题解 CF1781F Bracket Insertion
摘要:[Bracket Insertion](https://www.luogu.com.cn/problem/CF1781F) 神仙 DP 题,不愧是 tourist。 容易发现,括号序列一共有 种生成方式。 假如 `(` 为 ,`
题解 P4322 [JSOI2016]最佳团体
摘要:[P4322 [JSOI2016]最佳团体](https://www.luogu.com.cn/problem/P4322) 分数规划+树形背包。 可以根据推荐关系建出一颗树,然后如果选了一点,则该点到根上的所有点都必须选。 二分 ,定义每个结点的权值,然后判断选 个节点的最大
题解 CF868F Yet Another Minimization Problem
摘要:[Yet Another Minimization Problem](https://www.luogu.com.cn/problem/CF868F) 神仙题。 第一眼看上去就是 DP。 定义 表示当前点 ,分 段的最小费用。 $f_{i,j}= \min(f_{i
题解 [ARC153B] Grid Rotations
摘要:[[ARC153B] Grid Rotations](https://www.luogu.com.cn/problem/AT_arc153_a) 有思维含量的一题。 我们横纵坐标分开考虑,对于每一个矩形,每次操作会使其内部元素的横坐标上下对调。 纵坐标也同理,左右对调。 而这种反转操作我们显然可以直
题解 CF1775E The Human Equation
摘要:[The Human Equation](https://www.luogu.com.cn/problem/CF1775E) 思维题。 我们考虑每次 数组加一减一对于其前缀和 的影响。 可以发现,假设相邻两次加一和减一的位置分别为 和 ,那么 在 $[l
题解 CF1775D Friendly Spiders
摘要:[Friendly Spiders](https://www.luogu.com.cn/problem/CF1775D) 带有技巧的最短路。 如果 能到 ,说明 ,也就是有相同因子。 所以我们考虑对于每个数 ,向他的所有质因子连一条长度为 的边,
题解 P5426 [USACO19OPEN]Balancing Inversions G
摘要:来一篇简单易懂的良心题解。  由于数值不是 就是 ,我们可以考虑将逆序对的统计方式化简。 以左区间为例,设 为 的个数, 为第
题解 [ABC276F] Double Chance
摘要:很容易想到分类。 我们可以把 到 的球分为两类,一类是权值小于 ,另一类是权值大于 。 对于第一类, 加上小于 的球的个数乘以 。 对于第二类, 加上所有大于 的球的权值。 这显然可以用
题解 P4815 [CCO2014] 狼人游戏
摘要:看题目限制,可以发现如果将机器人作为点,指控和保护关系作为边,可以建出一个森林,就下来就是传统的树形背包了。 设 表示当前点为 ,子树内有 个狼人,当前点是否为狼人的方案数。 初始化: 当前点为狼: -
题解 P7165 [COCI2020-2021#1] Papričice
摘要:### 题面描述 给定一颗树,求分成三部分后的最小差异值。 ### 题解 暴力:每次枚举两个点,将其父边断掉,如果存在祖先关系则特判一下,复杂度 ,预计 50pts。 正解:dfs 搜索每个结点,砍掉它的父边,剩下的尽量等分(易证)。 这一步可以用 multiset 维护。 对于一个
题解 P8398 [CCC2022 S4] Good Triplets
摘要:显然,答案不好直接求,我们考虑用总数减去不合法的方案数。 为了不算重,我们每次只考虑当前点与圆心连线交圆周于一点所形成的半圆内的不合法情况,然后用组合数算出剩下两个点的选择方案数。  于是我们可以将其拆成许多的“块”,并分成两类,即前进方向为左右还是上下。 。 于是可以考虑这么做: 1. 通过 bfs 将每一个块预处理出来,并记录其编号、高度、类型(是否为高地)以及边缘的点。 2. 将每一个块按高度从大到小排序。 3. 依次枚举每个块: - 对于当前要处理的块,枚举其边界的所有点
题解 P7640 [BalticOI 2006 Day 2] CITY PLANNING
摘要:首先我们定义“圈”为与原点距离相等的点集。 ``` . . . 3 . . . . . 3 2 3 . . . 3 2 1 2 3 . 3 2 1 0 1 2 3 . 3 2 1 2 3 . . . 3 2 3 . . . . . 3 . . . ``` ### 暴力: 把圈放到堆里,然后每次取出代
题解 P2276 [HNOI2002]农场的果树
摘要:首先可以观察出一颗 个节点的二叉树,当其字典序最小的时候,其形态为一条向右偏的链,当其字典序最大的时候,是一条向左偏的链。 由于每一种编码对应唯一的一颗二叉树,我们可以先建树。 然后考虑树上分治,尝试以下三种方式: 1. 变大右子树的字典序 2. 变大左子树的字典序,并将右子树变成一条链 3