题目

在这里插入图片描述

输入输出范例

输入:nums = [1,1,2]
输出:2, nums = [1,2]
解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素


输入:nums = [0,0,1,1,1,2,2,3,3,4]
输出:5, nums = [0,1,2,3,4]
解释:函数应该返回新的长度 5 , 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4 。不需要考虑数组中超出新长度后面的元素。


题解

我们只需要对数组的元素进行比较,遇到相同的跳过,直接忽略,遇到不同的进行覆盖替换即可

class Solution {
public:
    int removeDuplicates(vector<int>& nums) 
    {
          int n=nums.size();
          if(n==0)return 0;
          int j=0;
          for(int i=1;i<n;i++)
          {
              if(nums[i]!=nums[j])
              {
                  j++;
                  nums[j]=nums[i];
              }
          }
          return j+1;
    }
};

版权声明:本文为kingJamesbond原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
原文链接:https://blog.csdn.net/kingJamesbond/article/details/118692521