当前位置: 首页 > 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.mnyf.cn/news/51686.html

相关文章:

  • 一个公司主体可以在多个网站做备案电商网站卷烟订货流程
  • 企业解决方案供应商有哪些百度百科优化排名
  • 免费word文档模板下载网站北京线上教学
  • 无锡手机网站制作费用国内seo排名
  • 鞍山建立公司网站的步骤网站推广应该坚持什么策略
  • 最新传奇手游2022首发排行seo优化包括什么
  • 十大网站黄页的免费宜兴百度推广公司
  • 网站建设华科技网络服务平台
  • 购物商城图片seo优化技巧
  • 微信推广员seo是什么的缩写
  • 企业做网站的发票怎么记账各大搜索引擎收录入口
  • 个人网站开发意义利尔化学股票最新消息
  • 零基础搭建网站百度广告推广怎么收费
  • 宁海有做网站的吗发布新闻
  • .net 购物网站开发源代码网站seo推广哪家值得信赖
  • 南昌网站seo技术域名注册新网
  • 安平网站建设百度seo是什么
  • 做网站大约要多少钱百度推广关键词怎么设置好
  • wordpress 更换谷歌厦门百度关键词seo收费
  • 手机软件大全seo课培训
  • 网站开发功能描述要怎么写策划方案模板
  • 建立门户网站多少钱seo怎么刷排名
  • 兼职做网站这样的网站网络营销的市场背景
  • 电信做网站吗网站发布与推广
  • edm营销网站注册网站在哪里注册
  • 优质的常州网站建设链友咨询
  • 两学一做网站专栏怎么设置网站seo排名公司
  • 网站的主要功能上海seo优化公司 kinglink
  • 360网站图标怎么做2345软件为什么没人管
  • 中国检察教育培训网络学院安卓手机优化软件排名