作者简介:C/C++ 、Golang 领域耕耘者,创作者
个人主页:作者主页
活动地址:CSDN21天学习挑战赛
题目来源: leetcode官网
如果感觉博主的文章还不错的话,还请关注➕ 、点赞👍 、收藏🧡三连支持一下博主哦~~~
给你一个 升序排列 的数组 nums ,请你 原地 删除重复出现的元素,使每个元素 只出现一次 ,返回删除后数组的新长度。元素的 相对顺序 应该保持 一致 。
由于在某些语言中不能改变数组的长度,所以必须将结果放在数组nums的第一部分。更规范地说,如果在删除重复项之后有 k 个元素,那么 nums 的前 k 个元素应该保存最终结果。
将最终结果插入 nums 的前 k 个位置后返回 k 。
不要使用额外的空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。
判题标准:
系统会用下面的代码来测试你的题解:
int[] nums = [...]; // 输入数组
int[] expectedNums = [...]; // 长度正确的期望答案
int k = removeDuplicates(nums); // 调用
assert k == expectedNums.length;
for (int i = 0; i < k; i++) {
assert nums[i] == expectedNums[i];
}
如果所有断言都通过,那么您的题解将被 通过。
示例1:
输入:nums = [1,1,2]
输出:2, nums = [1,2,_]
解释:函数应该返回新的长度 2 ,并且原数组 nums 的前两个元素被修改为 1, 2 。不需要考虑数组中超出新长度后面的元素。
示例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 。不需要考虑数组中超出新长度后面的元素。
此题是需要实现c++ 中的一个库函数unique()
, 具体功能是元素去重,即序列中所有相邻的重复元素只保留一个,将所有不重复元素放在前面,返回不重复元素最后一个的迭代器。
这里另外还介绍一个函数: distance()
: 作用于同一容器的 2 个同类型迭代器可以有效指定一个区间范围。简单来说,就是返回一个容器中的两个迭代器之间的长度。
实现方式1:
直接使用上面的库函数
实现方式2:双指针算法
算法步骤:
left
, right
right
指针遇到的数和前面不一样时,就将它指向的元素赋给left
指针,如果和前面元素一样,则跳过三种实现方式
class Solution {
public:
int removeDuplicates(vector<int>& nums) {
// 直接将后面的重复元素删除掉
// nums.erase(unique(nums.begin(), nums.end()), nums.end());
// return nums.size();
// 直接用distance 函数返回长度
// return distance(nums.begin(), unique(nums.begin(), nums.end()));
int k = 0;
for(int i = 0; i < nums.size(); i ++)
{
if(!i || nums[i] != nums[i - 1])
nums[k ++] = nums[i];
}
return k;
}
};
执行结果:
其中遍历一次, 时间复杂度为O(n)
如果觉得对你有帮助的话:
👍 点赞,你的认可是我创作的动力!
🧡 收藏,你的青睐是我努力的方向!
✏️ 评论,你的意见是我进步的财富!