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
    }
相关推荐
tankeven13 分钟前
HJ182 画展布置
c++·算法
CS_Zero2 小时前
无人机路径规划算法——EGO-planner建模总结—— EGO-planner 论文笔记(一)
论文阅读·算法·无人机
杰梵2 小时前
聚酯切片DSC热分析应用报告
人工智能·算法
@BangBang2 小时前
leetcode (4): 连通域/岛屿问题
算法·leetcode·深度优先
Ulyanov2 小时前
像素迷宫:路径规划算法的可视化与实战
大数据·开发语言·python·算法
Mr_pyx3 小时前
【LeetCode Hot 100】 除自身以外数组的乘积(238题)多解法详解
算法·leetcode·职场和发展
Trouvaille ~3 小时前
零基础入门 LangChain 与 LangGraph(五):核心组件上篇——消息、提示词模板、少样本与输出解析
人工智能·算法·langchain·prompt·输入输出·ai应用·langgraph
MOON404☾3 小时前
Chapter 002. 线性回归
算法·回归·线性回归
故事和你913 小时前
洛谷-数据结构-1-3-集合3
数据结构·c++·算法·leetcode·贪心算法·动态规划·图论
春栀怡铃声4 小时前
【C++修仙录02】筑基篇:类和对象(上)
开发语言·c++·算法