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
    }
相关推荐
dongf20194 分钟前
R语言KNN算法
算法·数据分析·r语言
小O的算法实验室25 分钟前
2025年IEEE TASE,基于双层耦合平均场博弈的大规模智能体集成任务分配与轨迹规划
人工智能·算法·机器学习
8Qi831 分钟前
LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅
算法·leetcode·二叉树·动态规划
地平线开发者31 分钟前
从 INT64 Div 算子约束到 Cast 修复全流程
算法
AI科技星34 分钟前
基于奇合数边界的离散解析数论与双螺旋宇宙本体大统一体系论文全部数学公式汇总表
人工智能·算法·机器学习·架构·学习方法
糖果店的幽灵38 分钟前
Pandas DataFrame 数据结构详解
数据结构·pandas
多彩电脑44 分钟前
Swift里字符串的索引
开发语言·swift
地平线开发者1 小时前
Horizon 模型多 Batch 配置
算法·自动驾驶
czhaii1 小时前
GB2312简体中文编码表
单片机·算法
8Qi81 小时前
LeetCode 121 & 122:股票买卖问题(DP 对比题解)✅
算法·leetcode·职场和发展·动态规划