此后如竟没有炬火 我便是唯一的光|

Day_Dreamer_D

园龄:3年6个月粉丝:3关注:16

随笔分类 -  题解

洛谷 P7971 [KSN2021] Colouring Balls 题解
摘要:纪念一下人生中第一道数据分治题。 Subtask 1&2 这一部分具有的特殊性质是颜色段连续,那我们可以判断当前与前一个的颜色数是否为 1,若是则颜色相同,否则让颜色 +1。 Code namespace AB { void solve() { int cur=1; ans[1]=1; for(in
66
1
0
洛谷 P4423 [BJWC2011]最小三角形 题解
摘要:求平面最近点对的时候有这样一种思路: 将所有点全部绕原点旋转同一个角度,然后按横坐标排序。 根据数学直觉,在随机旋转后,答案中的两个点在数组中肯定不会离得太远。 把这种思路运用到这题当中,我们旋转随机角度将点打乱之后枚举三角形的三个顶点即可。 坐标旋转公式: $$ x2=x1\cos\theta-y
32
0
0
accoders NOI #5047. 猜数游戏 题解
摘要:题目描述 Alice 和 Bob 玩游戏。 Alice 有一个 1 n 中的正整数 y。Bob 不知道这个数。 游戏中的每一轮,Bob 选一个正整数 x,并提问 Alice:y 是否大于等于 x?然后 Alice 需要回答是或否。 Alice 可以说至多一次谎。Bob 想要用尽量
182
0
1
矩阵树定理学习笔记 & 洛谷 P4111 [HEOI2015]小 Z 的房间 题解
摘要:矩阵树定理 拉普拉斯矩阵 无边权 设无向图 Gn 个结点,则拉普拉斯矩阵 L 是一个 n×n 的矩阵,满足: Li,i(iG) 的值为结点 i 的度数。 Li,j(i,jG,ij) 的值为结点 i,j 之间相连
63
0
0
CF 455D. Serega and Fun 题解
摘要:考虑分块做法。 我们以 n 为块长分块,套路地维护每个数在这个每块中的出现次数 cnt。 对于 2 操作,整块直接读取 cnt,其余的直接暴力查询。 对于 1 操作,如果在同一个块里,直接暴力去做。如果不在,我们就将最后一个元素插入第一个元素所在的块中,然后整块平移并更新
40
0
0
BZOJ 2194 快速傅里叶之二 题解
摘要:题目描述 求:ck=(ai×bik)。 推导 一般卷积是和一定,然而这个是差一定,于是我们考虑把 b 反过来(其实反 a 也可以)。 则 ck=n1i=k(ai×bn+ki)。 令 $d_k=\sum^{n-1
18
0
0
CF 464C Substitutes in Number 题解
摘要:前置知识:(a+b)(amodp+bmodp)(modp)。 同余定理使用后不能再修改数字。那么为了能用这个公式,我 们倒序处理每个数字。 定义 di10 的位数 1 次幂对 109+7 取模的值(数 i 经转化后的位数),bi
22
0
0
accoders NOI #5014. 树上询问(query) 题解
摘要:昨天刚刚做过一道类似的题,没想到在模拟赛当中出现了。 题目描述 有一棵 n 个结点的树,有 m 次询问,每次询问给你两个整数 l,r,问存在多少个整数 k 使得从 l 沿着 lr 的简单路径走 k 步恰好到达 k。 思路 考虑将一条 lr 的路
116
0
0
AcCoders 10477:【省选基础数据结构 树链剖分】【GDOI2016】疯狂动物城 题解
摘要:算法:树链剖分,可持久化线段树。 题目大意 给定 n 个结点的一棵树,m 次操作,操作有三种: 将 xy 最短路径上的所有点的权值加上 delta。 对于 xy 最短路径上的所有点 u,求 $\sum\sum^{\operatorname{dis}(u,y
52
0
0
CF 1012C. Hills 题解
摘要:题目传送门:Link。 算法:DP。 设计状态 第一眼看着道题就感觉像是 DP,再观察数据范围大概是 O(n2) 的时间复杂度。 因为要求多个 k 的答案,那么状态第一维显然是令多少个数满足条件,第二位就是算到第几个数。 dpi,j,0 表示前 i 个数有 j 个满足条件
31
0
0
洛谷 P3224 [HNOI2012]永无乡 题解
摘要:查询第 k 小值想到权值线段树。 合并操作想到线段树合并。 维护连通性想到并查集。 并查集合并方向应与线段树合并方向一致。 查询时,先求出并查集的根再在线段树上询问。 /* * Title: P3224 [HNOI2012]永无乡 * Source: 洛谷 * URL: https://www.
42
0
0
洛谷 P1552 [APIO2012] 派遣 题解
摘要:算法:线段树合并,离散化。 考虑任意一点 u 为领导者的情况。 显然,选出以 u 为根的子树中薪水 C 最少的 k 个结点(忍者),满足 Cm 的情况下使 k 尽可能大,这样 u 为领导者的最大满意度为 Lu×k。 考虑如何高效地求
61
0
0
POJ 1389. Area of Simple Polygons 题解
摘要:关于扫描线的介绍可以去看 OI Wiki。 但那上面的参考代码并不好,下面给出了带注释的 POJ 1389 题代码。 /* * Title: Area of Simple Polygons * Source: POJ * URL: http://poj.org/problem?id=1389 * A
59
0
0
AcCoders 10665:【省选基础 模拟】魔兽世界终极版 题解
摘要:一句话,大模拟,对着题意敲就完了。 干就完了,奥利给! 正正好好 618 行~ // 10665 Problem G:【省选基础 模拟】魔兽世界终极版 #include <iostream> #include <cstdio> #include <cstring> #include <string>
108
0
0
accoders NOI #5011. 小j 的组合 题解
摘要:哈密顿回路需要把每个点经过且只经过一遍,而在树上,这只能是一条链。 手推一下可以发现,操作相当于把每个点复制一遍,等同于给允许这个点多经过一次,有了这个结论就容易了许多。 在树上 DFS,每次返回到父亲就操作一次,但这样不能保证操作最少(当然,最后不需要回到根节点)。 不需要返回的点构成了一条链,剩
122
0
0
AcCoders 10699:多校B层冲刺NOIP20221015城市游历 题解
摘要:30pts 针对 n100 的数据,暴力对每个询问的接受程度跑一遍,时间复杂度 O(n3)。 70pts 显然,在 MST 上走最优。 针对 li,ri,ki105 的数据,考虑预处理接受程度为 i 时能去的不同种类的景点数 fi,答案为 $\su
149
0
0
AcCoders 10692:【2022NOIP联测10 10月17日】交换(swap) 题解
摘要:考虑把一次交换产生的贡献记录在交换的两个数字中较小的那个数字上。则构造一个好的序列的过程可以看成是:按照从小到大的顺序枚举每个数,每次选择将这个数放在序列的左边或右边。 不难发现,每次放到左边或右边需要移动的次数是初始序列中左边或右边比这个数大的数的个数,与其它数选择放在左边还是右边无关。 直接用树
88
0
0
POJ 3760. 魔兽世界(修订版) 题解
摘要:一句话,大模拟,照着题意敲就完了。 写的期间甚至因为疫情导致程序被锁在了机房 www //3760. 魔兽世界(修订版) #include <iostream> #include <cstring> #include <string> using namespace std; /**********
219
0
0
Ynoi 题解
摘要:0. 洛谷 P3987 我永远喜欢珂朵莉~ 算法:树状数组。 模型抽象 Trick:k2,最多 logaiai÷k 使得 ai=1。 证明:每次最少会使 ai 减半,最多 log 次就可以变为 1。 所以修改的复杂度
269
0
0
洛谷 P2158 [SDOI2008] 仪仗队 题解
摘要:来一发莫比乌斯反演的题解。 $$ \begin{split} ans & =\sum^{n-1}{i=1} \sum^{n-1}{j=1} [\gcd(i,j)=1]\ & = \sum^{n-1}{i=1} \sum^{n-1}{j=1} \sum_{d|\gcd(i,j)} \mu(d)\ &
122
0
0
点击右上角即可分享
微信分享提示
深色
回顶
收起