首页 > 其他分享 >26.删除有序数组中的重复项 Golang实现

26.删除有序数组中的重复项 Golang实现

时间:2024-09-18 09:46:22浏览次数:19  
标签:26 删除 nums 重复 元素 Golang 数组

题目描述:

给你一个 非严格递增排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。
考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:
更改数组 nums ,使 nums 的前 k 个元素包含唯一元素,并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
返回 k 。

题目分析:

  • 输入: 有序数组
  • 目标:唯一元素的个数
  • 要求: 原地删除(内存地址不能变)

由于要求原地删除,所以不能新建变量,并且Golang的slice没有删除操作,想删除只能新建一个变量,然后赋值。所以只能将重复值进行覆盖。使用双指针进行操作。指针j的目的是找到不重复元素的位置,当i,j指向相同的元素的时候,此时只有i向后移动,j不动,因为j 指针指向当前处理后的最后一个不重复元素。当移动i到与j的值不同的时候,j向后移,如果nums[i],nums[j]指向位置不同的话,他们中间的所有元素都将是重复元素(待替换)。

点击查看代码
func removeDuplicates(nums []int) int {
   j:=0
    for i := 0; i < len(nums); i++ {
        if nums[i]!=nums[j] {
            j++
            nums[j] = nums[i]
        }
    }
    return j+1
}

标签:26,删除,nums,重复,元素,Golang,数组
From: https://www.cnblogs.com/CharlseGo/p/18417956

相关文章