力扣-删除排序数组中的重复项

题目
给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。

不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/remove-duplicates-from-sorted-array

示例 1:

给定数组 nums = [1,1,2],

函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。

解题
两种方法

class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        //unique是将重复的元素移到数组的后面,结束返回第一个重复元素的位置的迭代器
        //然后用erase擦除从这个位置到结尾的元素
        nums.erase(unique(nums.begin(),nums.end()),nums.end());
        return nums.size();
    }
};

class Solution {
public:
    int removeDuplicates(vector<int>& nums) {
        //如果当前数组元素为空,返回0
        if(nums.empty()){
            return 0;
        }
        //初始化0位置
        int i = 0;
        //遍历循环对比
        for(int j = 1;j < nums.size();++j){
            //如果当前j位置的元素和i位置的元素不等,则将这个元素覆盖到i后面的一位
            if(nums.at(i) != nums.at(j)){
                nums.at(++i) = nums.at(j);
            }
        }
        //长度为i+1
        return i+1;
    }
};```


版权声明:本文为weixin_45907789原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接和本声明。