26. 删除有序数组中的重复项 (Swift版本)

题目描述

给你一个 非严格递增排列 的数组 nums ,请你删除重复出现的元素,使每个元素只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。然后返回 nums 中唯一元素的个数。

考虑 nums 的唯一元素的数量为 k ,你需要做以下事情确保你的题解可以被通过:

  • 更改数组 nums ,使 nums 的前 k 个元素包含唯一元素,并按照它们最初在 nums 中出现的顺序排列。nums 的其余元素与 nums 的大小不重要。
  • 返回 k 。

题解

最简单直接的方式 (借助外部数组)

swift 复制代码
    func removeDuplicates(_ nums: inout [Int]) -> Int {
        var result = [Int]()
        nums.forEach { integer in
            if !result.contains(integer) {
                result.append(integer)
            }
        }
        result.enumerated().forEach { idx, integer in
            nums[idx] = integer
        }
        return result.count
    }

原地删除 (双指针)

swift 复制代码
    func removeDuplicates(_ nums: inout [Int]) -> Int {
        let n = nums.count
        if n == 0 {
            return 0
        }
        var fast = 1, slow = 1
        while fast < n {
            if (nums[fast] != nums[fast - 1]) {
                nums[slow] = nums[fast]
                slow += 1
            }
            fast += 1
        }
        return slow
    }
相关推荐
yzp-13 小时前
算法 198. 打家劫舍 ---------动态规划学习
算法
好奇龙猫13 小时前
大学院-筆記試験練習:线性代数和数据结构(18)
数据结构·线性代数
小小王app小程序开发13 小时前
潮玩抽赏盲盒玩法开发全解析:算法、架构与合规风控
算法·架构
汉克老师13 小时前
GESP2025年12月认证C++三级真题与解析(单选题1-8)
c++·算法·位运算·string·gesp三级·gesp3级·数据范围
week_泽13 小时前
随机森林样本权重的计算-弱学习器
学习·算法·随机森林
Jasmine_llq14 小时前
《P2151 [SDOI2009] HH 去散步》
算法·矩阵快速幂·快速幂算法 + 自定义矩阵乘法·图的邻接矩阵(边状态版)·状态拆分 + 转移条件·模运算(防溢出 + 结果取模)·二进制快速幂
The Last.H14 小时前
Codeforces Round 1065 (Div. 3)A-C2
c++·算法
tudficdew14 小时前
类型安全容器设计
开发语言·c++·算法
naruto_lnq14 小时前
C++与Docker集成开发
开发语言·c++·算法
LYS_061814 小时前
寒假学习(7)(C语言7+模数电7)
c语言·学习·算法