P8649 [蓝桥杯 2017 省 B] k 倍区间(同余定理)

[蓝桥杯 2017 省 B] k 倍区间

题目描述

给定一个长度为 N 的数列,A_1,A_2, \\cdots A_N,如果其中一段连续的子序列 A_i,A_{i+1}, \\cdots A_j(i \\le j) 之和是 K 的倍数,我们就称这个区间 \[i,j\]K 倍区间。

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

输入格式

第一行包含两个整数 NK(1 \\le N,K \\le 10\^5)

以下 N 行每行包含一个整数 A_i(1 \\le A_i \\le 10\^5)

输出格式

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

样例 #1

样例输入 #1

```

5 2

1

2

3

4

5

```

样例输出 #1

```

6

```

提示

时限 2 秒, 256M。蓝桥杯 2017 年第八届

利用同余定理:当a mod k=b mod k 时,∣a−b∣mod k=0。

cpp 复制代码
#include<bits/stdc++.h>
#define int long long
using namespace std;
int n,k,s[100005],ans=0,xb[100005];
signed main(){
    cin>>n>>k;
    for(int i=1,t;i<=n;i++)
        cin>>t,s[i]=s[i-1]+t;
    for(int i=0;i<=n;i++)
        ans+=xb[s[i]%k]++;
    cout<<ans;
    return 0;
}
相关推荐
学历真的很重要2 小时前
【系统架构师】第二章 操作系统知识 - 第二部分:进程管理(详解版)
学习·职场和发展·系统架构·系统架构师
VT.馒头4 小时前
【力扣】2722. 根据 ID 合并两个数组
javascript·算法·leetcode·职场和发展·typescript
执着2595 小时前
力扣hot100 - 108、将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
LiLiYuan.6 小时前
【Cursor 中找不到LeetCode 插件解决办法】
算法·leetcode·职场和发展
南风知我意9576 小时前
【前端面试5】手写Function原型方法
前端·面试·职场和发展
技术狂人1687 小时前
2026 智能体深度解析:落地真相、红利赛道与实操全指南(调研 100 + 案例干货)
人工智能·职场和发展·agent·商机
努力学算法的蒟蒻8 小时前
day77(2.5)——leetcode面试经典150
面试·职场和发展
_OP_CHEN8 小时前
【算法基础篇】(五十五)卡特兰数封神之路:从括号匹配到二叉树构造,组合数学的万能钥匙!
算法·蓝桥杯·c/c++·组合数学·卡特兰数·算法竞赛·acm/icpc
June bug9 小时前
软件测试面试常见问答题2
面试·职场和发展