★k倍区间【第八届蓝桥杯省赛C++B组,第八届蓝桥杯省赛JAVAB组】
k倍区间
给定一个长度为
你能求出数列中总共有多少个 K 倍区间吗?
输入格式
第一行包含两个整数 N 和 K。
以下 N 行每行包含一个整数
输出格式
输出一个整数,代表 K 倍区间的数目。
数据范围
输入样例:
5 2
1
2
3
4
5
输出样例:
6
思路
Code
点击查看代码
#include<iostream>
#include<cstdio>
#include<cmath>
#include<algorithm>
#include<vector>
#define endl '\n'
using namespace std;
typedef long long LL;
const int N = 1e5 + 10;
LL cnt[N]; //妙!
int n,k;
LL ans,a1,a2;
int main(){
ios::sync_with_stdio(false);
cin.tie(0),cout.tie(0);
cin >> n >> k;
cnt[0] = 1;
//余数为0时存在长度为1的k倍区间
//基数为1则如果数组中存在有长度为1的k倍区间,范围变为(0~r)
for(int i = 1; i <= n; i ++ ){
a1 = a2; //前缀和只用当前和上一个:滚动数组优化空间
cin >> a2; //输入当前
a2 += a1; //自身求前缀和
a2 %= k; //求余数
ans += cnt[a2]; //先算ans后++维护l = (0~r-1)
cnt[a2] ++;
//这两段代码的意思是r固定时,从l = (0~r-1) 找到同余的个数
//则所记录的k倍区间的长度大于1
}
cout << ans;
return 0;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】