贤鱼的刷题日常--P2671 [NOIP2015 普及组] 求和

简介: 🍀学会求和题目
🏆今日学习目标:
🍀学会求和题目
✅创作者:贤鱼

请添加图片描述

题目

[NOIP2015 普及组] 求和

题目背景

NOIP2015 普及组 T3

题目描述

一条狭长的纸带被均匀划分出了$n$个格子,格子编号从$1$到$n$。每个格子上都染了一种颜色$color_i$用$[1,m]$当中的一个整数表示),并且写了一个数字$number_i$。

定义一种特殊的三元组:$(x,y,z)$,其中$x,y,z$都代表纸带上格子的编号,这里的三元组要求满足以下两个条件:

  1. $xyz$是整数,$x<y<z,y-x=z-y$
  2. $colorx=colorz$

满足上述条件的三元组的分数规定为$(x+z) \times (number_x+number_z)$。整个纸带的分数规定为所有满足条件的三元组的分数的和。这个分数可能会很大,你只要输出整个纸带的分数除以$10,007$所得的余数即可。

输入格式

第一行是用一个空格隔开的两个正整数$n$和$m,n$表纸带上格子的个数,$m$表纸带上颜色的种类数。

第二行有$n$用空格隔开的正整数,第$i$数字$number$表纸带上编号为$i$格子上面写的数字。

第三行有$n$用空格隔开的正整数,第$i$数字$color$表纸带上编号为$i$格子染的颜色。

输出格式

一个整数,表示所求的纸带分数除以$10007$所得的余数。

样例 #1

样例输入 #1

6 2
5 5 3 2 2 2
2 2 1 1 2 1

样例输出 #1

82

样例 #2

样例输入 #2

15 4
5 10 8 2 2 2 9 9 7 7 5 6 4 2 4
2 2 3 3 4 3 3 2 4 4 4 4 1 1 1

样例输出 #2

1388

提示

【输入输出样例 1 说明】

纸带如题目描述中的图所示。

所有满足条件的三元组为: $(1, 3, 5), (4, 5, 6)$。

所以纸带的分数为$(1 + 5) \times (5 + 2) + (4 + 6) \times (2 + 2) = 42 + 40 = 82$。

对于第 $1$ 组至第 $2$ 组数据, $1 ≤ n ≤ 100, 1 ≤ m ≤ 5$;

对于第$3$ 组至第 $4$ 组数据, $1 ≤ n ≤ 3000, 1 ≤ m ≤ 100$;

对于第 $5$ 组至第$ 6 $组数据, $1 ≤ n ≤ 100000, 1 ≤ m ≤ 100000$,且不存在出现次数超过$ 20 $的颜色;

对 于 全 部 $10$ 组 数 据 , $1 ≤ n ≤ 100000, 1 ≤ m ≤ 100000, 1 ≤ color_i ≤ m,1≤number_i≤100000$

思路

这道题我们分为两种方法讲
1:20分做法:

题目==要求==中说的非常详细

  1. $xyz$是整数,$x<y<z,y-x=z-y$
  2. $colorx=colorz$

所以我们三层循环遍历一遍肯定能全部找到
但是看看数据范围,100000?三层循环要么我炸要么时间复杂度炸
所以这种方法只有40分

2:AC做法:

需要用到一些数学内容(童鞋们不要慌,下面有详细解说)
首先明确一下目标
1压缩压缩下标
2压缩压缩颜色
==啊对,就这俩,不多吧,下面来看具体:==
因为 $xyz$是整数,$x<y<z,y-x=z-y$
所以 $2y=x+z$
所以 $x+y无论如何都为偶数(任何数字*2都为偶数)$
我们颜色也需要压缩一下,判断颜色的奇偶
这里我们用一个==z==数组来储存当前组内有多少数字,就是说单数组复数组,也可以理解为满足要求1的组,再用一个sum来储存前缀和,这个到后面会讲到
假设当前数字下标为$i_n,当前数字的值为num_n$
所以可以总结出一个式子
$(i_1+i_2)(n_1+n_2)+(i_1+i_3)(n_1+n_3)+(i_1+i_4)(n_1+n_4)+......(i_1+i_n)(n_1+n_n)$
去括号:
$i_1*n_1+i_1*n_2+i_1*n_1+i_1*n_3...+i_1*n_n$
乱七八糟,我们提取公因式
$i_1*(n_2+....+n_n)+(n-1)*i_1*n_1$
这里1-n,因为i1不能和他自己组合,所以最后乘的是n-1.提取出所有i1和n1,其他的是不是就是一个等差数列
可是还是有些不好表示,我们再处理一下
$i_1*(n_2+...n_n)+i_1*n_1+(n-1)*i_1*n_1-i_1*n_1$
前面加后面减,结果不变,我们再次提取公因式
$i_1*(n_1+..n_1)+(n-2)*i_1*n_1$
这样子是不是就做完了,这里我们可以通过前缀和提前获取我们需要的东西,下面来看看代码

代码

==20分做法,不想看的可以跳过==

#include<cmath>
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int n,c,num[1000001],col[100001];
int main(){
cin>>n>>c;
for(int i=1;i<=n;i++){
    cin>>num[i];
}
for(int i=1;i<=n;i++){
    cin>>col[i];
}
int ans=0;
for(int i=1;i<=n;i++){
    for(int j=i+1;j<=n;j++){
        for(int k=j+1;k<=n;k++){
            if(j-i==k-j&&col[i]==col[k]){//三层循环处理找答案
                ans+=(i+k)*(num[i]+num[k]);
                ans%=10007;
            }
        }
    }
}
cout<<ans%10007;
}

==AC做法:==

#include<cmath>
#include<cstdio>
#include<iostream>
#include<cstring>
using namespace std;
int n,c,num[1000001],col[100001];//num储存所有数字,col储存颜色
int main(){
cin>>n>>c;
for(int i=1;i<=n;i++){
    cin>>num[i];
}
int z[101010][3];//这里储存每个组有多少数字
int sum[1010100][3];//这里储存前缀和
for(int i=1;i<=n;i++){
    cin>>col[i];
    z[col[i]][i%2]++;//这个组的数字加1
    sum[col[i]][i%2]=(sum[col[i]][i%2]+num[i])%10007;//这个组前面所有的数字和加上当前加入的数字

}
int ans=0;
for(int i=1;i<=n;i++){
ans=(ans+i*(sum[col[i]][i%2]+(z[col[i]][i%2]-2)*num[i]%10007))%10007;
//这里就是按照上面题目所说处理
}
cout<<ans%10007;
}

🏆结束语

如果有需要的话可以订阅专栏,持续更新

请添加图片描述

相关文章
|
JavaScript
vue element plus Checkbox 多选框
vue element plus Checkbox 多选框
571 0
|
11月前
|
Java Android开发 Swift
安卓与iOS开发对比:平台选择对项目成功的影响
【10月更文挑战第4天】在移动应用开发的世界中,选择合适的平台是至关重要的。本文将深入探讨安卓和iOS两大主流平台的开发环境、用户基础、市场份额和开发成本等方面的差异,并分析这些差异如何影响项目的最终成果。通过比较这两个平台的优势与挑战,开发者可以更好地决定哪个平台更适合他们的项目需求。
263 1
|
存储 JavaScript Java
ROS CDK魔法书:点亮博客上云新技能(Java篇)
在阿里云资源编排服务ROS的Cloud Development Kit(ROS CDK)中,开发者可以使用编程语言(如TypeScript、Java等)定义云资源,简化了基础设施即代码(IaC)的管理。ROS CDK的Asset模块是用于处理本地文件到云端对象存储(如OSS)的工具,它通过元数据封装本地资源,然后配合ROS CDK的部署工具将文件上传至云端。通过一个将本地博客网站部署到OSS的案例,文章展示了如何使用ROS CDK的Asset模块和BucketDeployment来实现这一过程。
|
8月前
|
SQL 存储 运维
云端问道5期方案教学-基于 Hologres 轻量实时的高性能OLAP分析
本文介绍了基于Hologres的轻量实时高性能OLAP分析方案,涵盖OLAP典型应用场景及Hologres的核心能力。Hologres是阿里云的一站式实时数仓,支持多种数据源同步、多场景查询和丰富的生态工具。它解决了复杂OLAP场景中的技术栈复杂、需求响应慢、开发运维成本高、时效性差、生态兼容弱、业务间相互影响等难题。通过与ClickHouse对比,Hologres在性能、写入更新、主键支持等方面表现更优。文中还展示了小红书、乐元素等客户案例,验证了Hologres在实际应用中的优势,如免运维、查询快、成本节约等。
149 0
云端问道5期方案教学-基于 Hologres 轻量实时的高性能OLAP分析
|
存储 关系型数据库 MySQL
[重磅更新]PolarDB-X V2.3 集中式和分布式一体化开源发布
2023年云栖大会,PolarDB-X 正式发布 2.3.0版本,重点推出PolarDB-X标准版(集中式形态),将PolarDB-X分布式中的DN节点提供单独服务,支持paxos协议的多副本模式、lizard分布式事务引擎,可以100%兼容MySQL。同时在性能场景上,采用生产级部署和参数(开启双1 + Paxos多副本强同步),相比于开源MySQL 8.0.34,PolarDB-X在读写混合场景上有30~40%的性能提升,可以作为开源MySQL的最佳替代选择。
|
11月前
|
编解码 供应链 搜索推荐
虚拟现实与教育:沉浸式学习的潜力
【10月更文挑战第2天】虚拟现实(VR)技术正在革新教育领域,通过沉浸式体验提升学习效果和兴趣。本文探讨了VR在教育中的应用潜力,特别是在历史、地理、自然科学和语言教育中的案例。虽然面临设备成本和技术支持等挑战,但随着技术进步和成本降低,VR有望成为教育的重要工具,带来更丰富的学习体验。
|
算法 测试技术 持续交付
软件开发深度解析:从设计到单元构建
软件开发深度解析:从设计到单元构建
288 2
|
关系型数据库 MySQL OLAP
PolarDB +AnalyticDB Zero-ETL :免费同步数据到ADB,享受数据流通新体验
Zero-ETL是阿里云瑶池数据库提供的服务,旨在简化传统ETL流程的复杂性和成本,提高数据实时性。降低数据同步成本,允许用户快速在AnalyticDB中对PolarDB数据进行分析,降低了30%的数据接入成本,提升了60%的建仓效率。 Zero-ETL特性包括免费的PolarDB MySQL联邦分析和PolarDB-X元数据自动同步,提供一体化的事务处理和数据分析,并能整合多个数据源。用户只需简单配置即可实现数据同步和实时分析。
|
监控 安全 项目管理
GitLab 面试题及答案整理,最新面试题
GitLab 面试题及答案整理,最新面试题
366 0
Stable Diffusion——尝试如何正确的使用【AnimateDiff】生成动图——4种方法测试
Stable Diffusion——尝试如何正确的使用【AnimateDiff】生成动图——4种方法测试
351 0