蓝桥杯K倍区间(前缀和与差分,取模化简)

复制代码
输入
5 2
1 2 3 4 5
输出
6

**思路:**首先由连续子串和可以想用前缀和,由于加减法总和取模和分别取模结果不受影响,所以我们前缀和之后直接取模方便观察性质,本题前缀和:1,3,6,10,15取模之后:1,1,0,0,1,用差分就可以求出某段区间的和,如果该段区间和取模2为0,那么答案+1,但是如果直接for循环差分o(N**2)会超时,不妨找取模后的数组中相等的数,因为这样两数相减=0(取模后为0,那么没取模的时候一定是2的倍数)即可,只要o(n).

细节:

**(1)**由于差分找到的区间的左开右闭的,当有独立的前缀和=0,那么从一开始到它这段连续序列是可以的,未来避免单独讨论,在读入a[N],s[N]时我们从1 开始,最后找相同数字时我们从 0 开始。

(2) ans+=c[sum[i]];

c[sum[i]]++;这个顺序不能反,只有碰到>=2个相等才能有效

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
#define int long long
const int N=1e5+10;
int n,k,ans=0;
int a[N],sum[N],c[N];
signed main()
{
	ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
	cin>>n>>k;
	for(int i=1;i<=n;i++)
	{
		cin>>a[i];
		sum[i]=sum[i-1]+a[i];//sum[i-1]=0
		sum[i]%=k;
	}
	for(int i=0;i<=n;i++ )
	{
		ans+=c[sum[i]];
		c[sum[i]]++;
	}
	cout<<ans<<endl;
	return 0;
 } 
相关推荐
运筹vivo@7 分钟前
3043. 最长公共前缀的长度(Leetcode 每日一题)
c++·算法·leetcode·职场和发展·每日一题
测试19987 小时前
软件测试 - 单元测试总结
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例
csdn_aspnet12 小时前
Python 算法快闪 LeetCode 编号 70 - 爬楼梯
python·算法·leetcode·职场和发展
一只机电自动化菜鸟13 小时前
一建机电备考笔记(40) 建筑机电施工—排水管道施工(含考频+题型)
经验分享·笔记·学习·职场和发展·课程设计
做人求其滴15 小时前
面试经典 150 题 380 274
c++·算法·面试·职场和发展·力扣
小卡不对头15 小时前
软考中级通过率怎样?软考中级哪个通过率高
职场和发展·产品经理
中小企业实战军师刘孙亮19 小时前
家居建材营销新趋势:数字化、体验式与可持续方向-佛山鼎策创局破局增长咨询有限公司
职场和发展·产品运营·创业创新·需求分析·学习方法
此生决int19 小时前
算法从入门到精通——前缀和
c++·算法·蓝桥杯
凯瑟琳.奥古斯特19 小时前
传输层核心功能解析
开发语言·网络·职场和发展
天真小巫21 小时前
六年之约-2026.5.21
职场和发展