2024/3/14打卡k倍区间(8届蓝桥杯)——前缀和+优化***

题目

给定一个长度为 N 的数列,A1,A2,...AN,如果其中一段连续的子序列 Ai,Ai+1,...Aj 之和是 K 的倍数,我们就称这个区间 [i,j] 是 K 倍区间。

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

输入格式

第一行包含两个整数 N 和 K。

以下 N 行每行包含一个整数 Ai。

输出格式

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

数据范围

1≤N,K≤100000,

1≤Ai≤100000

输入样例:

复制代码
5 2
1
2
3
4
5

输出样例:

复制代码
6

思路

第一种O(n^3) 暴力枚举

java 复制代码
for(int i=1;i<=n;i++){ // 从1枚举到n 
    for(int j=1;j<=i;j++){ // 从1枚举到i
        for(int k=j;k<=i;k++) // 计算i~j的和
            sum += a[k]
        if(sum%k==0) res++; 
    }
}

第二种O(n^2) 使用前缀和(仍然过不了,甚至过的点是跟暴力一样的)

前缀和(一维+二维)-CSDN博客

java 复制代码
for(int i=1;i<=n;i++){
    for(int j=1;j<=i;j++){
        if((s[i]-s[j-1])%k==0) res++;
    }
}

第三种O(N) 在前缀和基础上优化

在第二种方法的第二层循环里面 ,目的是判断 ,即 判断两个余数是否相等如果在第 层循环里面,我们可以知道从 中有 哪些的前缀和 等于 ,那么这一段就是K倍区间。

新开一个数组 cnt[ ] ,存储前 i 个值的余数情况。

java 复制代码
cnt[0] = 1; // 如果某个数自身也可以整除k,说明取余为0,所以cnt[0]初始化为1,
for(int i=1;i<=n;i++){
    int t = s[i]%k; // i个值的前缀和对k取余
    res += cnt[t]; // 加上前 0~i-1 有相同的余数的个数
    cnt[t]++; // 第i个前缀和取余k的余数对应的cnt++
}

完整代码

java 复制代码
import java.io.*;

class Main{
    static int N = 100010;
    static int n,k;
    static int[] cnt = new int[N];
    static long res;
    static long[] s = new long[N];
    public static void main(String[] args) throws IOException{
        BufferedReader in = new BufferedReader(new InputStreamReader(System.in));
        String[] str = in.readLine().split(" ");
        n = Integer.parseInt(str[0]);
        k = Integer.parseInt(str[1]);

        for(int i=1;i<=n;i++){ // 求前缀和
            s[i] = s[i-1]+Integer.parseInt(in.readLine());
        }

        cnt[0] = 1;
        for(int i=1;i<=n;i++){
            long t = s[i]%k;
            res += cnt[(int)t];
            cnt[(int)t]++;
        }
        System.out.println(res);
    }
}
相关推荐
明明如月学长10 分钟前
AI 更新太快学不过来?我用OpenClaw打造专属AI学习工作流
算法
黎阳之光22 分钟前
【黎阳之光:以无线专网与视频孪生,赋能智慧广电与数字中国】
算法·安全·智慧城市·数字孪生
刀法如飞1 小时前
Agentic AI时代,程序员必备的算法思想指南
人工智能·算法·agent
刀法如飞1 小时前
Agentic AI时代程序员必备算法思想详解(附实战案例)
算法·ai编程·编程开发·agentic
飞Link2 小时前
告别盲目找Bug:深度解析 TSTD 异常检测中的预测模型(Python 实战版)
开发语言·python·算法·bug
记忆多3 小时前
c++名字空间 函数模版 左右值
开发语言·c++·算法
三伏5223 小时前
控制理论前置知识——相平面数学基础2(示例部分)
算法·平面·控制
2401_889884664 小时前
高性能计算通信库
开发语言·c++·算法
郝YH是人间理想4 小时前
Pandas库DataFrame数据结构
数据结构·pandas
不想看见4044 小时前
Hamming Distance位运算基础问题--力扣101算法题解笔记
算法