算法之区间和题目讲解

题干

难度:简单

题目分析

题目要求算出每个指定区间内元素的总和。

然而,区间在输入的最下面,所以按照暴力破解的思路,我们首先要遍历数组,把它的值都存进去。

然后,遍历下面的区间,从索引a到b,累加元素。

根据这个思路,我们会发现,暴力破解的代码如下:

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);

        // 读取数组的长度
        int len = in.nextInt();
        int[] s = new int[len];

        // 读取数组元素
        for (int i = 0; i < len; i++) {
            s[i] = in.nextInt();
        }

        // 读取区间并计算和
        while (in.hasNextInt()) {
            int a = in.nextInt();
            int b = in.nextInt();

            int sum = 0;
            // 暴力计算区间和
            for (int i = a; i <= b; i++) {
                sum += s[i];
            }

            // 输出结果
            System.out.println(sum);
        }

        in.close();
    }
}

我们分析一下这样写的时间复杂度。

假设数组长度为n,有m个查询,那时间复杂度就是O(m*n)级别的,有点太高了。

那么,有没有更好的时间复杂度的方法呢?

我们想到,如果算区间和,每次都从区间开始加到区间结束,那么要把区间从头到尾遍历一遍。

有没有什么办法,可以以O(1)级别的时间复杂度查询出区间和呢?

解决办法就是------------前缀和

简而言之,就是创建一个数组,存储累加之和。

比如新数组sum,sum[0]代表s[0],sum[1]代表s[0]+s[1],sum[2]代表s[0]+s[1]+s[2]

这样我们如果需要s[1]+s[2],只需要用sum[2]-sum[0]就行

代码

根据这个思路,我们编写代码

java 复制代码
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {

        Scanner in = new Scanner(System.in);

        int len = in.nextInt();
        int[] s = new int[len];
        for (int i = 0; i < len; i++) { //存储数组的值
            s[i] = in.nextInt();
        }

        int[] sum = new int[len];
        for (int i = 0; i < len; i++) {  //存储前缀和
            if (i == 0) {
                sum[i] = s[i];
            }else {
                sum[i] = s[i]+ sum[i - 1];
            }

        }

        while (in.hasNextInt()) {
            int a = in.nextInt();
            int b = in.nextInt();

            int all=0;

            if (a == 0) {
                all = sum[b];
            } else {
                all = sum[b] - sum[a-1];  //直接定位查询,是O(1)级别的复杂度
            }
            System.out.println(all);
            
        }
        in.close();
    }
}
相关推荐
计算机视觉农民工3 分钟前
机器学习有多少种算法?当下入门需要全部学习吗?
学习·算法·机器学习
ZStack开发者社区7 分钟前
ZStack文档DevOps平台建设实践
java·大数据·开发语言·devops
异常君15 分钟前
揭秘 Spring 验证机制:为何@Validated 在 Controller 层生效却在 Service 层失效?
java·后端·spring
Yharim17 分钟前
ruoyi-cloud分页是怎么回事
java·后端·微服务
掉鱼的猫17 分钟前
史上最强的 Java Solon v3.2.0 发布(并发高 700%;内存省 50%)
java·spring·mcp
地平线开发者18 分钟前
【智驾中的大模型 -2】VLM 在自动驾驶中的应用
算法·自动驾驶
柯ran19 分钟前
数据结构|排序算法(三)选择排序 堆排序 归并排序
数据结构·算法·排序算法
luckilyil19 分钟前
springboot自定义starter(避坑教学)
java·spring boot·spring
秋书一叶23 分钟前
Java工具类——实体类列表写入excel
java·开发语言·excel
MobiCetus26 分钟前
Linux Kernel 9
java·linux·运维·服务器·windows·ubuntu·gnu