蓝桥杯k倍区间(前缀和、余数统计)

题目描述

给定一个长度为 NN 的数列,A1,A2,⋯ANA1​,A2​,⋯AN​,如果其中一段连续的子序列 Ai,Ai+1,⋯AjAi​,Ai​+1,⋯Aj​ ( i≤ji≤j ) 之和是 KK 的倍数,我们就称这个区间 [i,j][i,j] 是 K 倍区间。

你能求出数列中总共有多少个 KK 倍区间吗?

输入描述

第一行包含两个整数 NN 和 KK( 1≤N,K≤1051≤N,K≤105 )。

以下 N 行每行包含一个整数 AiAi​ ( 1≤Ai≤1051≤Ai​≤105 )

输出描述

输出一个整数,代表 K 倍区间的数目。

输入输出样例

示例

输入

复制代码
5 2
1
2
3
4
5

输出

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;

int main()
{
long long n,k;
  cin>>n>>k;

  long long sum=0;
  long long ans=0;
  int cnt[100006]={0};
  cnt[0]=1;
  for(int i=1;i<=n;i++)
  {
    int x;
    cin>>x;
    sum+=x;
    int y=sum%k;
    ans+=cnt[y];
    cnt[y]++;
  }
  cout<<ans;
  return 0;
}
复制代码
6
相关推荐
心中有国也有家9 小时前
PaddlePaddle 适配 NPU 的技术全解析——从算子接入到端到端性能优化
人工智能·分布式·算法·性能优化·架构·paddlepaddle
兰令水9 小时前
topcode【随机算法题】【2026.5.24打卡-java版本】
java·开发语言·算法
徐小夕9 小时前
面试官:AI生成到90%突然断了,你的解决方案是什么?(万字长文深度剖析)
前端·vue.js·算法
EnCi Zheng9 小时前
09a-斯坦福 CS336 作业一:BPE分词器
开发语言·python·算法
生成论实验室10 小时前
用事件关系网络重新理解AI(二):损失函数、优化器与深度学习的动力学
数据结构·人工智能·深度学习·算法·语言模型
霍霍的袁10 小时前
【C++初阶】缺省参数(默认参数)详细讲解
开发语言·c++·算法
计算机安禾10 小时前
【算法分析与设计】第2篇:计算模型与渐进复杂性分析
算法
生成论实验室10 小时前
事件、信息荷与六维态势空间——每一个事件都是一次空间的弯曲
人工智能·算法·语言模型·可信计算技术·安全架构
budingxiaomoli10 小时前
递归,搜索与回溯算法--递归
算法
风味蘑菇干10 小时前
Stream基础题目
java·算法