当前位置: 首页 > article >正文

蓝桥杯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个相等才能有效

#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;
 } 

 


http://www.kler.cn/a/539808.html

相关文章:

  • 数组与指针1
  • go-elasticsearch创建ik索引并进行查询操作
  • Elasticsearch 生产集群部署终极方案
  • 智能化食品安全管理:AI视频监控在大型商场的技术方案
  • 如何搭建DeepSeek R1的训推环境?
  • 多路文件IO
  • Ollama + AnythingLLM + Deepseek r1 实现本地知识库
  • iOS主要知识点梳理回顾-2-多线程
  • docker常用命令及案例
  • 【R语言】相关系数
  • Ubuntu禁止内核自动更新
  • 【Java八股】JVM
  • 为什么推荐使用 LabVIEW 开发
  • 日志2025.2.9
  • Java面试题整理一(反射)
  • c++初始
  • Ext系列文件系统(上)
  • C++ Primer 逗号运算符
  • Linux中getifaddrs函数
  • 【人工智能】解码语言之谜:使用Python构建神经机器翻译系统
  • 51单片机之冯·诺依曼结构
  • 爬虫学习笔记之requests库的使用
  • 数据可视化技术综述(4)衡量数据的性能指标的十大维度
  • [Deepseek+Heygen+剪映]快速生产数字人讲解的视频内容
  • 【机器学习】scikit-learn调用KNN算法并手动模仿封装自己的KNN算法
  • 深入解析 FFmpeg 的 AAC 编解码过程