leetcode_26删除有序数组中的重复项

1. 题意

给定一个重复数组,删除其中的重复项目。

2. 题解

双指针

一个指针指向有序不重复数组的最后一个数,另外一个数遍历整个数组,若两个指针对应用的数不相同,有序数组的指针右移,将数填入。

  • 代码一
c 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        

        int sz = nums.size();
        int cnt = 0;

        for (int i = 1;i < sz; ++i) {
            if (nums[i] != nums[cnt]) {
                nums[++cnt] = nums[i];
            }
        }
        return cnt + 1;
    }
};
  • 通解
    只要 n u m s [ l e n − 1 ] ≠ n u m s [ j ] nums[len - 1]\ne nums[j] nums[len−1]=nums[j], 就需要将 n u m s [ j ] nums[j] nums[j]给放入有序数组。推广一下,如果相同的数不超过 k k k个,就只需要 n u m s [ l e n − k ] ≠ n u m s [ j ] nums[len - k] \ne nums[j] nums[len−k]=nums[j]。
cpp 复制代码
class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        

        int sz = nums.size();
        int cnt = 1;

        for (int i = 1;i < sz; ++i) {
            if (nums[i] != nums[cnt - 1]) {
                nums[cnt++] = nums[i];
            }
        }
        return cnt;
    }
};
相关推荐
bkspiderx11 分钟前
C++中的访问控制:private、public与protected的深度解析
开发语言·c++·算法·访问控制·private·public·protected
ullio1 小时前
arc207c - Combine to Make Non-decreasing
算法
ZhuNian的学习乐园1 小时前
LLM对齐核心:RLHF 从基础到实践全解析
人工智能·python·算法
iAkuya1 小时前
(leetcode)力扣100 31K个一组翻转链表(模拟)
算法·leetcode·链表
铭哥的编程日记1 小时前
二叉树遍历的递归和非递归版本(所有题型)
算法
&永恒的星河&1 小时前
告别过时预测!最新时序新SOTA:TimeFilter教会模型“选择性失明”
人工智能·深度学习·算法·时序预测·timefilter·时序算法
闻缺陷则喜何志丹1 小时前
【二分查找】P9029 [COCI 2022/2023 #1] Čokolade|普及+
c++·算法·二分查找·洛谷
leiming62 小时前
c++ set容器
开发语言·c++·算法
C雨后彩虹2 小时前
猜密码问题
java·数据结构·算法·华为·面试
ullio2 小时前
div1+2. 2180C - XOR-factorization
算法