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

外贸产品推广网站谷歌官网网址

外贸产品推广网站,谷歌官网网址,一年的百度指数,猎头公司和人力资源公司的区别🚀 博主介绍:大家好,我是无休居士!一枚任职于一线Top3互联网大厂的Java开发工程师! 🚀 🌟 在这里,你将找到通往Java技术大门的钥匙。作为一个爱敲代码技术人,我不仅热衷…

在这里插入图片描述

🚀 博主介绍:大家好,我是无休居士!一枚任职于一线Top3互联网大厂的Java开发工程师! 🚀

🌟 在这里,你将找到通往Java技术大门的钥匙。作为一个爱敲代码技术人,我不仅热衷于探索一些框架源码和算法技巧奥秘,还乐于分享这些宝贵的知识和经验。

💡 无论你是刚刚踏入编程世界的新人,还是希望进一步提升自己的资深开发者,在这里都能找到适合你的内容。我们共同探讨技术难题,一起进步,携手度过互联网行业的每一个挑战

📣 如果你觉得我的文章对你有帮助,请不要吝啬你的点赞👍分享💕和评论哦! 让我们一起打造一个充满正能量的技术社区吧!


目录标题

      • 题目
      • 问题分析
      • 解决方案步骤
      • Java实现代码
      • 代码解析
      • 复杂度分析


题目

输入一个长度为n的整型数组array,数组中的一个或连续多个整数组成一个子数组,找到一个具有最大和的连续子数组。

  1. 子数组是连续的,比如[1,3,5,7,9]的子数组有[1,3],[3,5,7]等等,但是[1,3,7]不是子数组
  2. 如果存在多个最大和的连续子数组,那么返回其中长度最长的,该题数据保证这个最长的只存在一个
  3. 该题定义的子数组的最小长度为1,不存在为空的子数组,即不存在[]是某个数组的子数组
  4. 返回的数组不计入空间复杂度计算

要解决这个问题,我们可以使用一种经典的算法,称为Kadane’s Algorithm,用于找到具有最大和的连续子数组。接下来,我们将结合题目的要求来实现这个算法。

问题分析

  1. 最大和子数组:我们需要遍历数组并维护当前子数组的和,同时更新最大和。
  2. 长度管理:在更新最大和时,我们需要记录对应的子数组的长度,以确保在出现相同最大和时选择长度最长的子数组。
  3. 边界条件:需要注意数组至少有一个元素的情况。

解决方案步骤

  1. 初始化当前和和最大和。
  2. 遍历数组,更新当前和。
  3. 如果当前和小于零,重置当前和和长度。
  4. 在每次更新最大和时,记录当前子数组的长度。
  5. 返回最大和的子数组及其长度。

Java实现代码

public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** @param array int整型一维数组 * @return int整型一维数组*/public int[] maxSubArray(int[] array) {int n = array.length;if (n == 0) return new int[0]; // 不应该发生,题目假定至少一个元素int maxSum = Integer.MIN_VALUE; // 最大和int currentSum = 0;              // 当前和int maxLength = 0;               // 最大和子数组的长度int currentLength = 0;           // 当前子数组的长度int startIndex = 0;              // 记录最大和子数组的起始索引int tempStartIndex = 0;          // 记录当前子数组的起始索引for (int i = 0; i < n; i++) {currentSum += array[i];currentLength++;// 更新最大和及其长度if (currentSum > maxSum) {maxSum = currentSum;maxLength = currentLength;startIndex = tempStartIndex;} else if (currentSum == maxSum) {// 如果当前和等于最大和,比较长度if (currentLength > maxLength) {maxLength = currentLength;startIndex = tempStartIndex;}}// 如果当前和小于零,重置if (currentSum < 0) {currentSum = 0;currentLength = 0;tempStartIndex = i + 1; // 更新起始索引}}// 构造结果数组int[] result = new int[maxLength];for (int i = 0; i < maxLength; i++) {result[i] = array[startIndex + i];}return result;}
}

代码解析

  1. 初始化变量

    • maxSum 用于存储最大和,初始值设为 Integer.MIN_VALUE 以处理负数情况。
    • currentSum 用于记录当前子数组的和。
    • maxLengthcurrentLength 分别用于记录最大和子数组的长度和当前子数组的长度。
    • startIndextempStartIndex 用于追踪子数组的起始位置。
  2. 遍历数组

    • 对于每个元素,更新 currentSumcurrentLength
    • 检查当前和是否大于最大和,如果是,更新最大和及其长度。
    • 如果当前和小于零,重置当前和和长度,并更新子数组的起始位置。
  3. 返回结果

    • 根据 startIndexmaxLength 构造最终的子数组并返回。

复杂度分析

  • 时间复杂度:(O(n)),只需遍历一次数组。
  • 空间复杂度:(O(1))(不计返回的结果数组)。

这种方法既高效又满足题目的所有要求。如果你有任何其他问题或需要进一步的帮助,请告诉我!

乐于分享和输出干货的WXGZG:JavaPersons

http://www.yayakq.cn/news/559190/

相关文章:

  • 网站建设为什么这么贵规划案例网站
  • 网站模板 英文个人社保缴费基数是什么意思
  • 合肥网站建设维护自然堂官方网站建设
  • 成品网站源码是1688吗营销策划方案怎么写?
  • 网站开发广东亚马逊网站运营怎么做
  • 自做头像的网站wordpress整站导出
  • 医院网站建设医生需要做什么网站重复页面
  • 搭建织梦网站视频教程济南做网站互联网公司有哪些
  • 北京做网站好公司wordpress微信主题下载
  • 做网站需要php吗在上海注册公司有什么好处
  • 合肥网站建设sina网站开发技术架构
  • 整站优化案例如何用ps做网站标识
  • 网站首页设计排版要点wordpress页面发布后不显示
  • 徐州网站建设薇at57666y南宁网站seo公司哪家好
  • 网站建网站建站专业公司wordpress添加 下载文件
  • erp系统定制优化推广排名
  • 有没有免费注册域名的网站网站cms是什么意思
  • 望牛墩网站仿做专业的开发网站建设价格
  • 网站ui设计软件拉新项目官方一手平台
  • 做网站需要前台和后台吗怎么做网站外链接
  • 山东网站开发制作天津通用网站建设方案
  • 营销型企业网站建设步骤免费企业网站源码
  • 什么叫网站定位徐州煤棚网架公司
  • 网站的文件夹学动漫制作很烧钱吗
  • 产品摄影网站推荐我是站长网
  • 建设网站搞网络营销的总结群晖 docker wordpress
  • 网站官网域名要多少钱云服务器哪一家比较便宜
  • 一个域名可以做中英文两个网站吗cms网站地图模板
  • 网站后台程序开发昆明网站建设案例
  • 做暧暖爱视频网站柳州建设网栗园新居