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;
}
相关推荐
Morwit5 小时前
【力扣hot100】 416. 分割等和子集
数据结构·c++·算法·leetcode·职场和发展
宵时待雨6 小时前
优选算法专题3:二分查找
数据结构·c++·算法·leetcode·职场和发展
米粒17 小时前
力扣算法刷题 Day 52
算法·leetcode·职场和发展
浅念-9 小时前
LeetCode 模拟算法:用「还原过程」搞定编程题的入门钥匙
开发语言·c++·学习·算法·leetcode·职场和发展·模拟
阿Y加油吧9 小时前
算法二刷复盘|旋转排序数组二分双杀(LeetCode 33 & 153)
算法·leetcode·职场和发展
skywalker_119 小时前
力扣hot100(9-找到字符串中所有字母异位词;10-和为K的子数组)
算法·leetcode·职场和发展
嘻嘻哈哈樱桃9 小时前
牛客经典101题解题集--二分查找/排序
数据结构·算法·职场和发展
帅次9 小时前
Android 高级工程师面试参考答案:架构设计、Jetpack 与 Compose
android·面试·职场和发展·架构·composer·jetpack
人道领域9 小时前
【LeetCode刷题日记】20.有效的括号
算法·leetcode·职场和发展
蒸汽求职18 小时前
跨越 CRUD 内卷:半导体产业链与算力基建下的软件工程新生态
人工智能·科技·面试·职场和发展·软件工程·制造