题目
给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 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版权协议,转载请附上原文出处链接和本声明。