您的位置:首页 > 游戏 > 游戏 > html代码在线提取_什么网页游戏最火_整合营销网络推广_西安百度推广竞价托管

html代码在线提取_什么网页游戏最火_整合营销网络推广_西安百度推广竞价托管

2025/3/9 11:38:36 来源:https://blog.csdn.net/weixin_74888502/article/details/146059172  浏览:    关键词:html代码在线提取_什么网页游戏最火_整合营销网络推广_西安百度推广竞价托管
html代码在线提取_什么网页游戏最火_整合营销网络推广_西安百度推广竞价托管

LCR191

目录

  • 题目描述
  • 示例
  • 思路分析
  • 代码段
  • 代码逐行讲解
  • 复杂度分析
  • 总结的知识点
  • 整合
  • 总结

题目描述

给定一个数组 arrayA,返回一个数组 arrayB,其中 arrayB[i]arrayA 中除了 arrayA[i] 之外所有元素的乘积。

注意:

  • 不能使用除法。
  • 时间复杂度为 O(n),空间复杂度为 O(1)(输出数组不计入空间复杂度)。

示例

示例 1

输入:

arrayA = [1, 2, 3, 4]

输出:

[24, 12, 8, 6]

解释:

  • arrayB[0] = 2 * 3 * 4 = 24
  • arrayB[1] = 1 * 3 * 4 = 12
  • arrayB[2] = 1 * 2 * 4 = 8
  • arrayB[3] = 1 * 2 * 3 = 6

示例 2

输入:

arrayA = [0, 1, 2, 3]

输出:

[6, 0, 0, 0]

解释:

  • arrayB[0] = 1 * 2 * 3 = 6
  • arrayB[1] = 0 * 2 * 3 = 0
  • arrayB[2] = 0 * 1 * 3 = 0
  • arrayB[3] = 0 * 1 * 2 = 0

思路分析

问题核心

我们需要计算数组中每个元素左边所有元素的乘积和右边所有元素的乘积,然后将两者相乘得到结果。

思路拆解

  1. 初始化数组
    • 使用两个辅助数组 leftright,分别存储每个元素左边和右边所有元素的乘积。
  2. 计算左边乘积
    • 从左到右遍历数组,计算每个元素左边所有元素的乘积。
  3. 计算右边乘积
    • 从右到左遍历数组,计算每个元素右边所有元素的乘积。
  4. 计算结果
    • leftright 数组对应位置的值相乘,得到最终结果。

代码段

class Solution {public int[] statisticalResult(int[] arrayA) {if (arrayA.length == 0) {return new int[0];}int len = arrayA.length;int[] arrayB = new int[len];int[] left = new int[len];int[] right = new int[len];left[0] = 1;for (int i = 1; i < len; i++) {left[i] = left[i - 1] * arrayA[i - 1];}right[len - 1] = 1;for (int i = len - 2; i >= 0; i--) {right[i] = right[i + 1] * arrayA[i + 1];}for (int i = 0; i < len; i++) {arrayB[i] = left[i] * right[i];}return arrayB;}
}

在这里插入图片描述


代码逐行讲解

  1. 空数组处理

    if (arrayA.length == 0) {return new int[0];
    }
    
    • 如果输入数组为空,则返回空数组。
  2. 初始化变量

    int len = arrayA.length;
    int[] arrayB = new int[len];
    int[] left = new int[len];
    int[] right = new int[len];
    
    • 获取数组长度,并初始化结果数组 arrayB 和辅助数组 leftright
  3. 计算左边乘积

    left[0] = 1;
    for (int i = 1; i < len; i++) {left[i] = left[i - 1] * arrayA[i - 1];
    }
    
    • 从左到右遍历数组,计算每个元素左边所有元素的乘积。
  4. 计算右边乘积

    right[len - 1] = 1;
    for (int i = len - 2; i >= 0; i--) {right[i] = right[i + 1] * arrayA[i + 1];
    }
    
    • 从右到左遍历数组,计算每个元素右边所有元素的乘积。
  5. 计算结果

    for (int i = 0; i < len; i++) {arrayB[i] = left[i] * right[i];
    }
    
    • leftright 数组对应位置的值相乘,得到最终结果。
  6. 返回结果

    return arrayB;
    
    • 返回结果数组 arrayB

复杂度分析

时间复杂度

  • 遍历数组三次,时间复杂度为 O(n)

空间复杂度

  • 使用了两个辅助数组 leftright,空间复杂度为 O(n)

总结的知识点

  1. 辅助数组

    • 使用辅助数组存储中间结果,简化计算。
  2. 遍历数组

    • 通过遍历数组计算左边和右边的乘积。
  3. 乘积计算

    • 将左边和右边的乘积相乘,得到最终结果。

整合

class Solution {public int[] statisticalResult(int[] arrayA) {if (arrayA.length == 0) {return new int[0];}int len = arrayA.length;int[] arrayB = new int[len];int[] left = new int[len];int[] right = new int[len];left[0] = 1;for (int i = 1; i < len; i++) {left[i] = left[i - 1] * arrayA[i - 1];}right[len - 1] = 1;for (int i = len - 2; i >= 0; i--) {right[i] = right[i + 1] * arrayA[i + 1];}for (int i = 0; i < len; i++) {arrayB[i] = left[i] * right[i];}return arrayB;}
}

总结

通过辅助数组和遍历,能够高效地计算数组中每个元素左边和右边所有元素的乘积,并得到最终结果。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com