🏆今日学习目标:🍀学会求和题目 ✅创作者:贤鱼
@TOC
题目
[NOIP2015 普及组] 求和
题目背景
NOIP2015 普及组 T3
题目描述
一条狭长的纸带被均匀划分出了个格子,格子编号从到。每个格子上都染了一种颜色用当中的一个整数表示),并且写了一个数字。
定义一种特殊的三元组:,其中都代表纸带上格子的编号,这里的三元组要求满足以下两个条件:
- 是整数,
满足上述条件的三元组的分数规定为。整个纸带的分数规定为所有满足条件的三元组的分数的和。这个分数可能会很大,你只要输出整个纸带的分数除以所得的余数即可。
输入格式
第一行是用一个空格隔开的两个正整数和表纸带上格子的个数,表纸带上颜色的种类数。
第二行有用空格隔开的正整数,第数字表纸带上编号为格子上面写的数字。
第三行有用空格隔开的正整数,第数字表纸带上编号为格子染的颜色。
输出格式
一个整数,表示所求的纸带分数除以所得的余数。
样例 #1
样例输入 #1
样例输出 #1
样例 #2
样例输入 #2
样例输出 #2
提示
【输入输出样例 1 说明】
纸带如题目描述中的图所示。
所有满足条件的三元组为: 。
所以纸带的分数为。
对于第 组至第 组数据, ;
对于第 组至第 组数据, ;
对于第 组至第$ 6 $组数据, ,且不存在出现次数超过$ 20 $的颜色;
对 于 全 部 组 数 据 ,
思路
这道题我们分为两种方法讲 1:20分做法:
题目要求中说的非常详细
- 是整数,
- 所以我们三层循环遍历一遍肯定能全部找到 但是看看数据范围,100000?三层循环要么我炸要么时间复杂度炸 所以这种方法只有40分
2:AC做法:
需要用到一些数学内容(童鞋们不要慌,下面有详细解说) 首先明确一下目标 1压缩压缩下标 2压缩压缩颜色 啊对,就这俩,不多吧,下面来看具体: 因为 是整数, 所以 所以 我们颜色也需要压缩一下,判断颜色的奇偶 这里我们用一个z数组来储存当前组内有多少数字,就是说单数组复数组,也可以理解为满足要求1的组,再用一个sum来储存前缀和,这个到后面会讲到 假设当前数字下标为 所以可以总结出一个式子 去括号: 乱七八糟,我们提取公因式 这里1-n,因为i1不能和他自己组合,所以最后乘的是n-1.提取出所有i1和n1,其他的是不是就是一个等差数列 可是还是有些不好表示,我们再处理一下 前面加后面减,结果不变,我们再次提取公因式 这样子是不是就做完了,这里我们可以通过前缀和提前获取我们需要的东西,下面来看看代码
代码
20分做法,不想看的可以跳过
AC做法:
🏆结束语:
如果有需要的话可以订阅专栏,持续更新 🔥一文了解数据库操作--mysql(25分钟)欢迎你的到来🔥