博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
LeetCode OJ:Remove Duplicates from Sorted Array II(移除数组中的重复元素II)
阅读量:6133 次
发布时间:2019-06-21

本文共 1073 字,大约阅读时间需要 3 分钟。

Follow up for "Remove Duplicates":

What if duplicates are allowed at most twice?

For example,

Given sorted array nums = [1,1,1,2,2,3],

Your function should return length = 5, with the first five elements of nums being 1122 and 3. It doesn't matter what you leave beyond the new length.

 

典型的双指针问题,维护两个指针不断更新就可以了,代码如下:

1 class Solution { 2 public: 3     int removeDuplicates(vector
& nums) { 4 int sz = nums.size(); 5 if(!sz) return 0; 6 int start = 0;//第二个指针 7 int i = 0;//第一个指针 8 int count = 0; 9 int key = nums[0];10 for(; i < sz; ++i){11 if(nums[i] == key)12 count++;13 else{14 for(int k = 0; k < min(2, count); ++k)15 nums[start++] = key;//更改数组元素,指针前移16 key = nums[i];17 count = 1;18 }19 }20 for(int k = 0; k < min(2, count); ++k)21 nums[start++] = key;22 return start;23 }24 };

 

转载于:https://www.cnblogs.com/-wang-cheng/p/4922080.html

你可能感兴趣的文章
构建之法阅读笔记三
查看>>
写给对前途迷茫的朋友:五句话定会改变你的人生
查看>>
并行程序设计学习心得1——并行计算机存储
查看>>
JAVA入门到精通-第86讲-半双工/全双工
查看>>
bulk
查看>>
js document.activeElement 获得焦点的元素
查看>>
C++ 迭代器运算
查看>>
【支持iOS11】UITableView左滑删除自定义 - 实现多选项并使用自定义图片
查看>>
day6-if,while,for的快速掌握
查看>>
JavaWeb学习笔记(十四)--JSP语法
查看>>
【算法笔记】多线程斐波那契数列
查看>>
java8函数式编程实例
查看>>
jqgrid滚动条宽度/列显示不全问题
查看>>
在mac OS10.10下安装 cocoapods遇到的一些问题
查看>>
angularjs表达式中的HTML内容,如何不转义,直接表现为html元素
查看>>
css技巧
查看>>
Tyvj 1728 普通平衡树
查看>>
[Usaco2015 dec]Max Flow
查看>>
javascript性能优化
查看>>
多路归并排序之败者树
查看>>