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

网站关键词推广方案安装百度到桌面

网站关键词推广方案,安装百度到桌面,个人网站 建设,xampp下wordpress使用双指针来解决此问题,关键词“有序”数组,一个 index 指针用于构建新数组,一个 i 指针用于遍历整个数组 以下是代码的中文解释以及算法思想: 算法思想 这道题要求对一个有序数组进行去重,使得每个元素最多出现两…

在这里插入图片描述

使用双指针来解决此问题,关键词“有序”数组,一个 index 指针用于构建新数组,一个 i 指针用于遍历整个数组

以下是代码的中文解释以及算法思想:

算法思想

这道题要求对一个有序数组进行去重,使得每个元素最多出现两次。我们需要在原数组上进行操作,不能使用额外的空间。为了实现这个要求,我们可以使用双指针法来完成:

  1. 初始化两个指针

    • index 指针表示下一个可以插入的有效位置(用于构建结果数组),它初始值为 2,因为前两个元素无论如何都可以直接保留。
    • i 指针遍历整个数组,从第三个元素开始检查(因为我们允许每个元素最多出现两次,所以不需要检查前两个元素)。
  2. 条件检查

    • 对于每个元素 nums[i],我们检查它是否等于 nums[index - 2]。如果不等,则表示 nums[i] 至少可以插入到当前构建的结果数组中。
    • 如果 nums[i] != nums[index - 2],则将 nums[i] 放到 nums[index] 位置上,并将 index 指针向后移动一位,准备下一个位置。
  3. 返回结果

    • 最终 index 的值就是新数组的长度,因为 index 指针的值代表了有效数组的长度。
    • 原数组前 index 个元素就是去重后的数组,且每个元素最多出现两次。

代码示例

public class Solution {public int removeDuplicates(int[] nums) {if (nums.length <= 2) return nums.length;int index = 2; // 从第三个元素开始检查for (int i = 2; i < nums.length; i++) {// 如果当前元素 nums[i] 不等于 nums[index - 2],说明该元素可以加入if (nums[i] != nums[index - 2]) {nums[index] = nums[i];index++;}}return index;}
}

具体解释

  • 数组长度小于等于 2:如果数组长度不超过 2,直接返回数组长度,因为每个元素都可以出现两次。
  • 遍历数组
    • 从第三个元素开始(i = 2),逐个检查每个元素 nums[i]
    • 如果当前元素 nums[i] 不等于 nums[index - 2],表示当前元素没有超过出现两次的限制。
    • 将当前元素 nums[i] 放到 nums[index] 位置上,然后将 index 向后移动一位。
  • 返回结果index 的值就是数组去重后的长度,数组的前 index 个元素就是符合要求的结果。

复杂度分析

  • 时间复杂度:O(n),因为我们只遍历了一遍数组。
  • 空间复杂度:O(1),因为我们在原数组上进行操作,没有使用额外的空间。

示例

假设输入数组为 {1, 1, 1, 2, 2, 3}

  • 初始状态:index = 2
  • 遍历:
    • i = 2nums[i] = 1nums[index - 2] = 1,相等,跳过此元素。
    • i = 3nums[i] = 2nums[index - 2] = 1,不相等,将 nums[i] 赋值给 nums[index]index 增加 1。
    • i = 4nums[i] = 2nums[index - 2] = 1,不相等,将 nums[i] 赋值给 nums[index]index 增加 1。
    • i = 5nums[i] = 3nums[index - 2] = 2,不相等,将 nums[i] 赋值给 nums[index]index 增加 1。
  • 最终结果:返回的长度 index = 5,即 {1, 1, 2, 2, 3}

java 代码如下:

class Solution {public int removeDuplicates(int[] nums) {// if (nums.length <= 2) return nums.length;int index = 2;for(int i = 2; i < nums.length; ++i) {if(nums[i] != nums[index - 2]) { //注意是index - 2, 而不是 i - 2nums[index++] = nums[i];}}return index;}
}

为什么这行代码的判断条件不是nums[i] != nums[i - 2]

if (nums[i] != nums[index - 2]) {

这是一个很好的问题。之所以判断条件写成 nums[i] != nums[index - 2] 而不是 nums[i] != nums[i - 2],是因为我们希望使用 index 指针来追踪构建新数组的有效长度,并确保每个元素最多出现两次。下面是具体原因:

原因解释

  1. index 指针的作用

    • index 指针代表的是新数组的当前位置,也就是我们构建的、符合条件的数组的长度。
    • index - 2 始终指向新数组的倒数第二个元素。因此,nums[index - 2] 可以用来判断当前的 nums[i] 是否已经出现了两次。
  2. 避免原数组的重复元素影响判断

    • 如果直接用 nums[i - 2],它表示的是原数组的倒数第二个元素。然而,我们的目标是构建一个新的符合条件的数组,这个数组并不直接等同于原数组。
    • 例如,在原数组中,某个元素可能已经出现多次,但在新数组(由 index 控制)中它可能只出现了一次。因此,判断条件需要使用 nums[index - 2] 而不是 nums[i - 2]
  3. 控制新数组的内容

    • 通过 nums[index - 2],我们可以确保只有符合条件的元素才被添加到新数组中,避免出现超过两次的重复。
    • 如果使用 nums[i - 2],则我们判断的是原数组中的元素而不是新构建的数组,可能会导致多次重复的元素被错误地加入。

举例说明

假设输入数组为 {1, 1, 1, 2, 2, 3}

  • 初始时 index = 2,我们从第三个元素(i = 2)开始遍历。

    • i = 2 时,nums[i] = 1,如果我们使用 nums[i - 2] 进行判断,那就是 nums[0] = 1。此时,它会与 nums[i] 相等,判断条件为 false,意味着它会被加入到新数组中,导致 1 出现三次,这是不符合题意的。
    • 而使用 nums[index - 2](即 nums[0] = 1)作为判断条件时,我们可以正确地跳过这个元素,避免多余的重复。

通过使用 index 指针,我们有效地控制了新数组的内容,并保证每个元素最多出现两次。

http://www.ds6.com.cn/news/91722.html

相关文章:

  • 一级a做爰片凤凰网站解释seo网站推广
  • 网站备案 法人身份证今日国内新闻10则
  • 合肥大型网站制怎么在百度上做广告
  • 云服务器ecs做网站sem公司
  • 美的公司网站建设的目的青岛网站关键词优化公司
  • 做视频用的网站有哪些正规的培训学校
  • 怎么做一个动态网站吗seo北京网站推广
  • 萍乡网站建设公司信息流广告投放渠道
  • 赣州网站设计哪里好电商网站建设
  • 一个做网站的公司年收入真正永久免费的建站系统有哪些
  • 沈阳网约车公司重庆百度整站优化
  • wordpress 页面固定外贸网站seo
  • 合肥最好的网站建设公司排名网络推广深圳有效渠道
  • 贵阳有哪家做网站建设好点的广告推广平台网站
  • 网站建设起到计划和指导作用营销管理系统
  • 厦门市城乡建设局网站河北网站推广
  • 静安西安网站建设青岛网站建设方案优化
  • 网站开发的软件环境有哪些百度推广客服
  • 余姚做网站62752762目前好的推广平台
  • 营销网站建设培训知名的建站公司
  • 优化师是做什么的seo优化的优点
  • 北京做网站公司的排名搜索图片
  • b站做简介的网站鞋子软文推广300字
  • 北京建站模板企业seo网站优化公司
  • 电子商务网站设计分析怎么做免费的电脑优化软件
  • 工作人员否认陈道明演庆余年2seo刷排名工具
  • 浅谈学校网站建设seo包括什么
  • 网站个人和企业有什么区别灰色关键词快速排名
  • 广州英文网站建设谷歌搜索引擎网址
  • 重庆网站的推广方式网站推广的途径有哪些