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
    }
相关推荐
cpp_25012 分钟前
P1910 L 国的战斗之间谍
数据结构·c++·算法·题解·洛谷·背包dp
yu85939584 分钟前
时延估计的互相关算法(MATLAB实现)
开发语言·算法·matlab
逸风尊者6 分钟前
2026 主流 Claw 类产品技术报告
人工智能·后端·算法
楼田莉子9 分钟前
同步/异步日志系统:工具类以及日志的简单模块
linux·服务器·数据结构·c++
强盛机器学习~11 分钟前
考虑异常天气和太阳辐射下基于强化学习的无人机三维路径规划
算法·matlab·无人机·强化学习·路径规划·无人机路径规划·q-learning
Pixlout15 分钟前
《7元接口体系》v1.0
网络·算法·硬件工程
SUNNY_SHUN16 分钟前
不需要Memory Bank:CMDR-IAD用2D+3D双分支重建做工业异常检测,MVTec 3D 97.3%
论文阅读·人工智能·算法·3d
Matlab光学21 分钟前
Matlab 复现:分数阶&整数阶OAM 变换
算法·matlab·拓扑学
Severus_black36 分钟前
C实现双向链表和相关函数!巨详细!
c语言·数据结构·链表·list
凌波粒38 分钟前
LeetCode--459.重复的子字符串(字符串/KMP算法)
算法·leetcode·职场和发展