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

豆包MarsCode:前缀和计算问题

问题描述

在这里插入图片描述


思路分析

问题理解

小S的任务是计算一个整数数组 nums 的前缀和。前缀和是指从数组开始到某个位置的所有元素的累加值,形成一个新数组。例如:

  • 输入数组:nums = [4, 5, 1, 6]
  • 前缀和数组:[4, 9, 10, 16]
    • 4 = 4
    • 9 = 4 + 5
    • 10 = 4 + 5 + 1
    • 16 = 4 + 5 + 1 + 6

解决步骤

我们需要构建一个新数组 prefixSum,其元素是输入数组 nums 的前缀和。关键步骤如下:

1. 定义结果数组

  • 新建一个数组 prefixSum,长度与输入数组 nums 相同,用于存储前缀和。

2. 特殊情况处理

  • 如果数组是空数组(nums.length == 0),直接返回空数组。

3. 逐步计算前缀和

  • 第一个位置的前缀和等于数组第一个元素本身:
    • prefixSum[0] = nums[0]
  • 从第二个元素开始,每个位置的前缀和等于前一个位置的前缀和加上当前元素:
    • prefixSum[i] = prefixSum[i - 1] + nums[i]

4. 遍历数组

  • 使用循环遍历数组,从第一个元素累加到最后一个元素,将每次计算的结果存入 prefixSum

伪代码总结

  1. 创建结果数组 prefixSum,长度与 nums 相同。
  2. 如果 nums 为空,则直接返回 prefixSum
  3. prefixSum[0] 初始化为 nums[0]
  4. 遍历数组,从第二个元素开始:
    • prefixSum[i] = prefixSum[i - 1] + nums[i]
  5. 返回结果数组 prefixSum

核心公式

  • 对于数组的第 i i i 个位置,前缀和的计算公式为:

    p r e f i x S u m [ i ] = p r e f i x S u m [ i − 1 ] + n u m s [ i ] prefixSum[i] = prefixSum[i - 1] + nums[i] prefixSum[i]=prefixSum[i1]+nums[i]

  • 边界条件:第一个元素:

    p r e f i x S u m [ 0 ] = n u m s [ 0 ] prefixSum[0] = nums[0] prefixSum[0]=nums[0]


参考代码(Java)

public class Main {
    public static int[] solution(int[] nums) {
  
        int[] prefixSum = new int[nums.length];
        if (nums.length == 0) return prefixSum;

        // 初始化第一个元素
        prefixSum[0] = nums[0];

        // 计算其余元素的前缀和
        for (int i = 1; i < nums.length; i++) {
            prefixSum[i] = prefixSum[i - 1] + nums[i];
        }

        return prefixSum;
    }

    public static void main(String[] args) {
        System.out.println(java.util.Arrays.equals(solution(new int[]{4, 5, 1, 6}), new int[]{4, 9, 10, 16}));
        System.out.println(java.util.Arrays.equals(solution(new int[]{2, 2, 2, 2}), new int[]{2, 4, 6, 8}));
        System.out.println(java.util.Arrays.equals(solution(new int[]{7, 3, 9, 4}), new int[]{7, 10, 19, 23}));
        System.out.println(java.util.Arrays.equals(solution(new int[]{1, 2, 3}), new int[]{1, 3, 6}));
    }
}

代码分析

1. 方法签名

public static int[] solution(int[] nums)
  • 输入
    • 参数 nums 是一个整数数组,表示输入数组。
  • 输出
    • 返回一个新的整数数组,表示 nums 的前缀和。

2. 初始化结果数组

int[] prefixSum = new int[nums.length];
  • 创建一个与 nums 等长的数组 prefixSum,用于存储计算出来的前缀和。

3. 边界条件检查

if (nums.length == 0) return prefixSum;
  • 如果输入数组是空的,则直接返回空的前缀和数组。

4. 初始化第一个前缀和

prefixSum[0] = nums[0];
  • 第一个位置的前缀和是输入数组的第一个元素。

5. 循环计算前缀和

for (int i = 1; i < nums.length; i++) {
    prefixSum[i] = prefixSum[i - 1] + nums[i];
}
  • 从数组的第二个元素开始:
    • 使用公式:prefixSum[i] = prefixSum[i - 1] + nums[i]
    • 当前的前缀和等于前一个前缀和加上当前元素值。

6. 返回结果

return prefixSum;
  • 返回计算好的前缀和数组。

运行过程解析

示例 1: 输入 [4, 5, 1, 6]

  • 初始化:prefixSum = [0, 0, 0, 0]
  • 步骤
    • prefixSum[0] = 4
    • prefixSum[1] = prefixSum[0] + nums[1] = 4 + 5 = 9
    • prefixSum[2] = prefixSum[1] + nums[2] = 9 + 1 = 10
    • prefixSum[3] = prefixSum[2] + nums[3] = 10 + 6 = 16
  • 结果[4, 9, 10, 16]

示例 2: 输入 [2, 2, 2, 2]

  • 初始化:prefixSum = [0, 0, 0, 0]
  • 步骤
    • prefixSum[0] = 2
    • prefixSum[1] = prefixSum[0] + nums[1] = 2 + 2 = 4
    • prefixSum[2] = prefixSum[1] + nums[2] = 4 + 2 = 6
    • prefixSum[3] = prefixSum[2] + nums[3] = 6 + 2 = 8
  • 结果[2, 4, 6, 8]

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

相关文章:

  • C语言自定义数据类型详解(二)——结构体类型(下)
  • 文本左右对齐
  • Ubuntu 20.04安装Protocol Buffers 2.5.0
  • 【论文投稿-第八届智能制造与自动化学术会议(IMA 2025)】HTML, CSS, JavaScript:三者的联系与区别
  • 物业巡更系统在现代社区管理中的优势与应用探讨
  • 【落羽的落羽 数据结构篇】顺序表
  • 【flutter版本升级】【Nativeshell适配】nativeshell需要做哪些更改
  • 《深度揭秘:TPU张量计算架构如何重塑深度学习运算》
  • npm常见报错整理
  • .strip()用法
  • Nacos统一配置管理
  • read+write实现:链表放到文件+文件数据放到链表 的功能
  • 第1章 量子暗网中的血色黎明
  • 17【棋牌游戏到底有没有透视】
  • games101-(3/4)变换
  • 弹性分组环——RPR技术
  • python Fabric在自动化部署中的应用
  • 使用 Python 和 scikit-learn 实现 KNN 分类:以鸢尾花数据集为例
  • 【由浅入深认识Maven】第3部分 maven多模块管理
  • fastadmin中require-form.js的data-favisible控制显示隐藏
  • 基于Flask的哔哩哔哩综合指数UP榜单数据分析系统的设计与实现
  • S4 HANA定义税码(FTXP)
  • 【江苏省乡镇街道边界】面图层shp格式arcgis数据+乡镇名称和编码wgs84无偏移内容测评
  • 基于SpringBoot多数据源解决方案
  • qt.qpa.plugin: Could not find the Qt platform plugin “dxcb“ in ““
  • 算法【01背包】