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

湛江优化网站排名搜索引擎优化是什么?

湛江优化网站排名,搜索引擎优化是什么?,惠州网站建设设计,专业网站设计软件工具问题描述 思路分析 问题理解 小S的任务是计算一个整数数组 nums 的前缀和。前缀和是指从数组开始到某个位置的所有元素的累加值,形成一个新数组。例如: 输入数组:nums [4, 5, 1, 6]前缀和数组:[4, 9, 10, 16] 4 49 4 510 …

问题描述

在这里插入图片描述


思路分析

问题理解

小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.dinnco.com/news/75879.html

相关文章:

  • 网站二级栏目图片识别 在线百度识图
  • 怎样做微信推广网站吸引人的微信软文
  • 建设网站需要学什么程序短视频培训课程
  • 网站优化软件排名5月疫情第二波爆发
  • 呼市网站设计免费投放广告平台
  • 怎么做好网站开发_设计数据分析工具
  • 网站架构思维导图sem培训班培训多少钱
  • asp.net开发的网站搜索广告
  • 济宁疫情最新情况重庆seo网站推广优化
  • 检测一个网站用什么软件做的方法佛山网络推广培训
  • 帮人做网站赚钱东莞全网营销推广
  • 跟做网站相关的法律自己怎么搭建网站
  • 网站建设需要数学重庆seo推广运营
  • 亦庄建设局网站东莞百度快速排名
  • 温岭做网站公司只需要手机号的广告
  • 有没有做网站的高手友情链接交换源码
  • 做网站论文研究方法怎么写百度一下你就知道百度官网
  • 西安网站制作哪家好河池网站seo
  • 移动应用开发干什么的网站怎么优化关键词排名
  • 只做网站的人员工资外链链接平台
  • 湖滨区建设局网站徐州网络推广服务
  • 网站里的图片是怎么做的镇江seo快速排名
  • 思行做网站网站在线客服系统 免费
  • 建站公司都是如何为建站服务定价的网站建设的意义和目的
  • 新东方线下培训机构官网深圳百度seo代理
  • 免费推广网站入口2023附近有学电脑培训班吗
  • 网站开发进度缓慢流量推广怎么做
  • 专业的营销型网站建设朝阳区seo搜索引擎优化怎么样
  • 网站建设行业企业发展前景免费可用的网站源码
  • 磁力猫最佳搜索引擎入口百度seoo优化软件