自定义博客皮肤VIP专享

*博客头图:

格式为PNG、JPG,宽度*高度大于1920*100像素,不超过2MB,主视觉建议放在右侧,请参照线上博客头图

请上传大于1920*100像素的图片!

博客底图:

图片格式为PNG、JPG,不超过1MB,可上下左右平铺至整个背景

栏目图:

图片格式为PNG、JPG,图片宽度*高度为300*38像素,不超过0.5MB

主标题颜色:

RGB颜色,例如:#AFAFAF

Hover:

RGB颜色,例如:#AFAFAF

副标题颜色:

RGB颜色,例如:#AFAFAF

自定义博客皮肤

-+
  • 博客(48)
  • 收藏
  • 关注

原创 细菌的繁殖与扩散(23.12-22)_题解

本题就是单纯的模拟,考验代码能力,直接写就可以。

2024-02-19 19:38:05 537

原创 单词排序(23.12-24)_题解

本题就是单纯的模拟,考验代码能力。

2024-02-18 20:17:47 489

原创 a 的 b 次方模 p(1e18)_题解

直接采用快速幂算法,注意到算法中包含乘法,而直接乘会溢出,那么再用龟速乘(快速幂改)的乘法即可通过本题。

2024-02-17 20:42:37 429

原创 a 乘 b 模 p_题解

【快速幂】算法题。面对a×bmodp这个结构,直接求必然溢出 long long,任何基本结构都不好使。模仿快速幂算法是先将b二进制分解(假设b的二进制表示为b59​b58​b57​...b2​b1​b0​a×b∑i059​bi​×a×2ia×bmodp∑i059​((bi​×a×2imodp))modp通过上面的式子,我们将原本的a×b经由b。

2024-02-16 23:53:36 811

原创 a 的 b 次方模 p_题解

【快速幂】算法模板题。面对abmodp这个结构,并没有什么显而易见的切入点,直接求必然超时Ob。而快速幂算法是先将b二进制分解(假设b的二进制表示为b29​b28​b27​...b2​b1​b0​ab∏i029​bi​×a2iabmodp∏i029​((bi​×a2imodp))modp通过上面的式子,我们将原本的ab经由b的二进制拆分转化成了 30 个(因为2301。

2024-02-16 00:10:21 1086

原创 T^T_题解

当直接算没有太好的方式,那么可以尝试枚举不一样的东西。若枚举第一个 T 的位置(i∈1n),那么计算答案时还需要枚举中间 ^ 的位置(j∈i1n),然后再枚举最后一个 T 的位置(k∈j1n)这样直接枚举需要计算的次数可以达到On3级别,显然不够。一个容易想到的优化是最后一个 T 可以通过预处理,计算出区间j1n中有多少个 T,每个 T 对答案都可以造成 +1 的影响,这个预处理可以通过后缀和完成。那么原算法需要的计算次数可以优化成On2级别,仍然不够。

2024-02-15 01:05:33 857

原创 末两位数(1992)_题解

指数函数增长速率过快,直接计算中间过程任何一种基本类型都无法存储。通过乘法运算的规律,可以发现末两位数只和末两位数相关,故直接对中间结果保留末两位数(mod 100)即可避免乘法溢出。

2024-02-13 20:41:46 991

原创 数的种类_题解

数据是分散的,如果可以用某种方式整理好,问题也许就迎刃而解了。比如说:排序。当数据已经排好序,再求解其中元素种类实际上就等价于求解数组的“段数”了。故排序后从前往后扫描累计答案即可。

2024-02-12 22:55:18 516 2

原创 n 个数的前缀最大值_题解

暴力遍历前i个数时间复杂度为On2会超时。记第i个答案为ansi​ansi​maxa1​a2​...ai​maxmaxa1​a2​...ai−1​ai​maxansi−1​ai​。故递推求解即可。

2024-02-11 19:19:29 1007

原创 方格定位2_题解

本题较为简单,直接找规律即可。

2024-02-11 00:15:21 378

原创 最大优势(1e5)_题解

首先可以知道数组A和数组B的顺序均没有关系,所以我们首先将数组A和数组B进行排序,然后考虑两个数组的第一个元素。ABABA。

2024-02-09 23:20:17 917

原创 方格定位1_题解

将原数减 1 后看作是四进制数,那么十位代表的就是所在行号减 1 的值,个位代表的就是所在列号减 1 的值。

2024-02-09 02:13:46 425

原创 下一个排列_题解

此题属于找规律题,我们可以把一个序列的全排列写出来,然后对比找规律,比如序列 1 2 3 4 5,全排列如下:1 2 3 4 51 2 3 5 41 2 4 3 51 2 4 5 31 2 5 3 41 2 5 4 31 3 2 4 51 3 2 5 4。

2024-02-08 01:04:26 413

原创 扑克牌游戏_题解

本题其实是改版的【约瑟夫环】问题,本质上还是依次找到某个位置的人,然后将这个人踢出队伍。环状结构可以使用循环取模的方式来模拟(也就是代码中pos的运行逻辑)。踢出操作可以使用标记数组(也就是代码中的vis),false 代表没有被踢出,true 代表已经被踢出。

2024-02-06 23:25:31 459

原创 输出超级玛丽2_题解

本题代码非常简单,直接一行一行对齐后输出即可,只是比较麻烦。

2024-02-06 01:18:07 456

原创 Xor 特殊情况_题解

注意到对于单次的查询区间lr0l−10r。对于任意区间0R可以找到最大的xx≤R且xmod40),0R的异或和等价于xR的异或和。(根据上一题题解中的【拓展】可以求证此结论)

2024-02-04 23:26:31 1034

原创 XOR Easy_题解

首先,暴力计算提交后会 TLE。其次,注意到x⊕y⊕yx(这里⊕代表异或操作)。最后,可以考虑使用前缀和算法,类比做出【异或前缀和】用于快速求解区间异或值。

2024-02-04 01:47:22 883

原创 XOR Hard_题解

注意到r和l较小,考虑暴力计算。

2024-02-03 01:42:28 424

原创 图像旋转_题解

设旋转后的图像为B,那么有Aij​Bjn−i​成立,故ij互换且i倒序输出即可。

2024-01-31 21:45:43 422

原创 矩阵转置_题解

设转置矩阵为B,那么有Aij​Bji​成立,故ij互换输出即可。

2024-01-30 22:35:48 409

原创 子矩形_题解

首先需要枚举到并判断所有可能的矩形。注意到gij​的取值范围非常的小,根据鸽笼原理,若矩形中元素数量超过 10,那么这样的矩形必然不合法(必然存在某种数出现的次数超过一次)。所以可以枚举矩形的某个角落(代码展示中枚举的是左上角坐标),然后再枚举其横纵延申的距离(不可能超过 10),通过上述推论可以发现可能合法的矩形其实非常少,且每个合法的矩形面积都不超过 10。故直接判断每个可能的矩形是否满足条件然后累加近答案中即可。

2024-01-29 23:28:37 442

原创 区间众数_题解

本题数据范围较小,时间限制较为宽松,可以考虑对每个区间扫描求众数,这样时间复杂度也可以接受。难点在于如何求给定数组的众数。可以通过计数数组,记录每种数出现的次数,然后通过扫描计数数组求解出现最多且最大的数。

2024-01-28 22:37:32 482

原创 两个数的乘积(unsigned int)_题解

在所有基础类型中能存下两个 unsigned int 乘积的也就 unsigned long long 了,故直接转换类型相乘即可。注意到可能乘积为负数,所以需要先判断符号再相乘输出即可。

2024-01-27 19:47:05 496

原创 鬼谷子的钱袋_题解

三个条件:1、钱袋数最小;2、能够构成 1~n 的所有数;3、不能有钱数相同的钱袋(1 除外)。现在只考虑前两个条件,构造的序列非常简单:1, 2, 4, 8, …,2kg(其中gn−∑i0k​2i且有g2k1成立(否则应该继续拆分)。首先,第二点容易证明,这里不予证明。第一点可以这么看,根据二进制相关知识可以发现124...2k可以构成小于2k1−1的所有数,特别的,若需要构成的数超过g那么先把g加进去,剩下的由上述序列补齐即可。

2024-01-26 20:56:28 951

原创 循环数组_题解

圆形排列中存在n对大小关系,如果存在一种合法的获得序列的方式,只有当存在不超过一对相邻小朋友,满足顺时针方向的小朋友的数字小于前一个小朋友。否则应当是无解的。

2024-01-25 20:21:47 410

原创 整数拆分_题解

其中有gn−∑i1k​成立。首先,基于【贪心】思想,假设当前没用过的最小的数为x,当前已用的数的和为sum,那么如果满足x1≤n−sum−x(用x这个数,且用完后剩余的数不小于后一个没用过的数),那么从字典序的定义出发,没有理由不使用x,也就是说拆分的数中必定包含x。利用上述推论,我们可以确定k的取值,且同时保证了拆分出序列满足“字典序”最小。

2024-01-24 18:47:49 969

原创 方格图剪纸游戏_题解

本题本质上是在问方格图四联通的状态下存在多少个极大矩形连通块。首先需要获得每个极大连通块的数据,这一点可以通过任意一种搜索完成。其次需要想办法判定当前连通块是否为矩形,可以用一种类似哈希的方式来完成,先求出整个连通块的外轮廓:最小和最大的横纵坐标。如此一来就获得了连通块的最小外接矩形,那么当且仅当连通块大小等于最小外接矩形大小时可以判定该连通块为矩形。forint;<=;++

2024-01-23 22:17:30 491

原创 求解区间段数(区间查询)_题解

若从前往后给每一段的元素赋值,第i段元素都赋值为i那么单次查询的答案就是两个端点处元素值的差值加 1(等价于中间存在多少个不同的元素)。例如数组 {2, 2, 3, 1, 3, 3} 就会被赋值为 {1, 1, 2, 3, 4, 4},当完成这个转化之后答案即可O1查询。

2024-01-22 21:42:30 488

原创 水平考试_题解

若存在一个已选项不属于正确答案则得分只能为 0,否则修改后得分必定为 10。所以判断上述条件是否成立即可。

2024-01-20 22:15:40 469

原创 还原差值数组、修改区间中元素_解法

Ai​∑j1i​Bj​,即每个元素都是一个前缀的和。

2024-01-19 19:50:14 520

原创 计算区间和_题解

直接统计每次询问的答案∑ili​ri​​Ai​即可。

2024-01-18 18:32:19 1093

原创 前缀 mex_题解

对于每个fk单独计算,那么等价于:给定k个数,求其 mex 值。

2024-01-17 19:23:36 1098

原创 最大子段和(3e3)题解

最大子段和暴力算法的分析及证明。

2024-01-16 17:48:19 1313 1

原创 关于 迪杰斯特拉 算法的 vis 标记数组与 spfa 算法的关系

对于最短路的两种算法的分析对比报告首先我们看两份代码: 这是 dij 的一份代码,其中删去了通常 dij 算法使用的 vis 标记数组。 题目链接#include <bits/stdc++.h>using namespace std;#define _for(i, a, b) for(int i = (a); i <= (b); i ++)inline void read(int &x, int &y, int &z) { scanf("%d%d

2021-10-13 17:09:08 320

原创 AtCoder_221_f Diameter set 题解

思维模拟加数学因为是最远点,故必定为直径。 我们知道树的直径并不为一。但是考虑一下,如果一棵树的直径中有奇数个结点,其实对于它来说其“中心结点”是每一条直径都必须通过的。(证明靠脑子)由上面那个想法我们可以类比出偶数结点的情况,那么其“中心”将会变成一条边,也就是说这条边两边的点是必被直径通过的存在。所以,当结点为偶数时,只需要分别计算两侧结点所领导的子树中有多少个结点的深度是直径的一半即可。但是在结点数为奇数个时问题就会有转变,因为类似于“菊花图”这种的,其实它隐含了一个组合问题,是

2021-10-09 11:59:00 192

原创 牛客/20328/J Sudoku Subrectangles 题解

优雅的暴力枚举首先,根据容斥原理,行不过 52 个元素必有重复(列同理)我们考虑枚举矩形的上下边界,由于上下边界间距离不会超过 52 所以共有 52*n 种上下边界。在上下边界之间查找可能的左右边界,假设矩形只有一行那么左右边界显然可以通过尺取判重的方式获得,又注意到本题中行列判重是分开的,所以我们可以把行列分开判断用一个数组(代码中是 ts 数组)记录当前列的向前最远可匹配位置。由于行列分开所以我们发现列中具有重复单词时,直接把当前位置 ts 值置为当前位置下标即可,否则用尺取法判断通过行

2021-10-08 17:55:21 106

原创 牛客/20328/A Minimum Cost Perfect Matching 题解

思维(构造)首先考虑什么时候 i & pi == 0 很显然的一点是当 pi == i ^ t (这里 t 代指一个二进制全为 1 的数)时成立 那么由此得知当 n 为 2 的幂的时候只需要不断地首尾交换数值就够了,而我们进一步的分析上面的条件可以发现如果将对应 i 的 0 位的数值换为 1 也是可以的,所以可以将后面的大数(高位有 1 的数)向前调整,就可以把高位的影响给消除。 综上所述,我们可以进行最高位的二进制进行划分,把所有的最高位的二进制以上的值向下调整,然后将二进制内的数

2021-10-08 11:55:34 95

原创 牛客/20328/C Bit Compression 题解

半记忆化搜索(空间与时间平衡的艺术)单论空间,用 a 数组直接记录;计算实践得出总时间复杂度一亿多一点。具体思路:前面 14 次幂采用暴力枚举: 3^14 ,后面 4 次幂采用记忆化搜索:2^(2^4) #include <bits/stdc++.h>using namespace std;#define ll long long #define _for(i, a, b) for(int i = (a); i <= (b); i ++)int n, m;bool

2021-10-08 11:28:25 83

原创 AtCoder_abc221_e LEQ 题解

1、任意两个节点 i,j (i < j)2、有 Ai <= Aj 3、那么:点对(i, j)对答案的贡献为( 2^(j - i - 1) ) 综上所述:每个点的贡献与前面所有小于等于其节点到这个点距离和有关系(非线性)观察 3 的式子之后发现若以 2^(i+1) 表示第 i 个点的价值,那么答案就是当前点用 2^j 表示后分别除上前方所有的符合条件节点的价值之后的和。关于除法,我们可以通过转化逆元处理出来由通过提取公因子 2^j 而将原式转化为加法,故本题可以用树状数组

2021-10-07 17:55:40 219

原创 湖南文理学院第十六届程序设计竞赛_题解

我是比赛链接A(AtCoder):平方不等式思路(huas_wlq):直接判断输出#include <bits/stdc++.h> /// 万能头文件(囊括了绝大多数的头文件,无需再定义每一个头文件) using namespace std;int main(){ int a, b, c; cin >> a >> b >> c; if(a * a + b * b < c * c) cout <&

2021-05-15 12:47:14 927 4

空空如也

空空如也

TA创建的收藏夹 TA关注的收藏夹

TA关注的人

提示
确定要删除当前文章?
取消 删除