(数论)(枚举)(前缀和)1230. K倍区间

简介: (数论)(枚举)(前缀和)1230. K倍区间

题目链接

1230. K倍区间 - AcWing题库

一些话

相似题型:隐藏的牛

NYIST(计科ACM&TC)第三次招新赛_栞那Kanna的博客-CSDN博客

切入点

如果其中一段连续的子序列 Ai,Ai+1,…Aj 之和是 K 的倍数,我们就称这个区间 [i,j]是 K 倍区间。

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

求有多少个类问题,符合枚举的特征

求区间和问题,符合前缀和特征

流程

1.看数据范围

数据范围

1≤N,K≤100000;

1≤Ai≤100000

n = 1e6,就算是区间枚举也会超时,O((n+1)*(n/2))

所以只能单重循环枚举

2.读题寻找条件

题目要求 区间和%k==0


即(s[i] - s[j-1] ) % k == 0


这需要双循环枚举两个点


此时开始想能不能把点拆开来,枚举一个就得到另一个


拆分公式


((s[i] % k) - (s[j-1] % k ) + k) % k == 0(这是一般的减法取余)


因为i与j-1的组合等价于j-1与i的组合,所以这两个值可以互相调换成差值大于0


的情况,此时就可以直接写成s[i] % k == s[j-1] % k;


枚举的时候只要s[i]%k的结果相同,就可以组成一个符合要求的区间。


所以就用类似牛腿问题的计数方法


ans += cnt[s[i]%k];


cnt[s[i]%k]++;


此外如果s[i] 自身%k== 0也要计数


cnt[s[i]%k] = 1,就可以让这种情况每次计入ans时比其他情况多1


套路


求情况数量题


一个数组、字符串内的元素是特殊的某种情况,组合可以形成满足题意的情况:


元素可以任意两两组合:


用一重循环


cnt统计当前特殊情况元素数量


if(特殊情况出现){


       res += cnt;,


       cnt++;


}


这是用前面出现的特殊情况元素和当前新出现的一个特殊情况元素组合,从而新组合成cnt种满足题意的情况


ac代码

#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
using namespace std;
const int N = 1e5 + 10;
int cnt[N];
long long f[N];
int main(){
    int n,k;
    cin >> n >> k;
    for(int i = 1;i <= n;i++) {
        scanf("%lld",&f[i]);
        f[i] += f[i-1];
    }
    cnt[0] = 1;
    long long ans = 0;
    for(int i = 1;i <=n;i++){
        ans += cnt[f[i]%k];
        cnt[f[i]%k]++;
    }
    cout << ans << endl;
    return 0;
}
目录
相关文章
|
5月前
|
存储 数据可视化 Python
单细胞RNA速率分析: scVelo入门教程
单细胞RNA速率分析: scVelo入门教程
单细胞RNA速率分析: scVelo入门教程
|
JavaScript 前端开发
Javascript Switch语句
Javascript Switch语句
185 0
Javascript Switch语句
|
4天前
|
弹性计算 人工智能 安全
云上十五年——「弹性计算十五周年」系列客户故事(第二期)
阿里云弹性计算十五年深耕,以第九代ECS g9i实例引领算力革新。携手海尔三翼鸟、小鹏汽车、微帧科技等企业,实现性能跃升与成本优化,赋能AI、物联网、智能驾驶等前沿场景,共绘云端增长新图景。
|
10天前
|
存储 弹性计算 人工智能
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
2025年9月24日,阿里云弹性计算团队多位产品、技术专家及服务器团队技术专家共同在【2025云栖大会】现场带来了《通用计算产品发布与行业实践》的专场论坛,本论坛聚焦弹性计算多款通用算力产品发布。同时,ECS云服务器安全能力、资源售卖模式、计算AI助手等用户体验关键环节也宣布升级,让用云更简单、更智能。海尔三翼鸟云服务负责人刘建锋先生作为特邀嘉宾,莅临现场分享了关于阿里云ECS g9i推动AIoT平台的场景落地实践。
【2025云栖精华内容】 打造持续领先,全球覆盖的澎湃算力底座——通用计算产品发布与行业实践专场回顾
|
2天前
|
云安全 人工智能 安全
Dify平台集成阿里云AI安全护栏,构建AI Runtime安全防线
阿里云 AI 安全护栏加入Dify平台,打造可信赖的 AI
|
9天前
|
人工智能 自然语言处理 自动驾驶
关于举办首届全国大学生“启真问智”人工智能模型&智能体大赛决赛的通知
关于举办首届全国大学生“启真问智”人工智能模型&智能体大赛决赛的通知
|
5天前
|
人工智能 运维 Java
Spring AI Alibaba Admin 开源!以数据为中心的 Agent 开发平台
Spring AI Alibaba Admin 正式发布!一站式实现 Prompt 管理、动态热更新、评测集构建、自动化评估与全链路可观测,助力企业高效构建可信赖的 AI Agent 应用。开源共建,现已上线!
471 12
|
3天前
|
编解码 文字识别 算法
一张图能装下“千言万语”?DeepSeek-OCR 用视觉压缩长文本,效率提升10倍!
一张图能装下“千言万语”?DeepSeek-OCR 用视觉压缩长文本,效率提升10倍!
361 10