【leetcode】【80】Remove Duplicates from Sorted Array II
2016-03-03 10:18
477 查看
一、问题描述
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
1,
1,
2,
2and
3.
It doesn't matter what you leave beyond the new length.
二、问题分析
题目要求最终的数组中前边部分满足要求即可,与Remove Duplicates一样,说明还是把后边的满足条件的数字往前挪。鉴于该题要求相同数字不能超过两次,显然如果还和Remove Duplicates一样使用一个指针来遍历很难满足要求,那么我们可以考虑双指针方法。从这个例子[1,1,1,2,2,3]来分析,前两个元素不需要管,从第三个数字来看,我们可以设置两个指针pre,cur,将cur指向第三个元素,将pre指向第二个元素,显然只有当nums[cur]==nums[pre]&&nums[cur]==nums[pre-1]的时候我们需要将cur继续往后移动寻找不同的元素;这时nums[cur]==2,不满足之前的判断条件,那么需要将2覆盖pre之后的元素,所以数组变为了[1,1,2,2,2,3],这时pre指向第一个2,cur指向第三个2,继续执行判断条件,pre可以++,这时虽然讲第三个2覆盖了第二个2因为是循环随意可能会出现同值覆盖的情况,然后继续执行后面的。有点啰嗦,看代码。三、Java AC代码
public int removeDuplicates(int[] nums) {if (nums.length <= 2)
return nums.length;
int prev = 1; // point to previous
int curr = 2; // point to current
while (curr < nums.length) {
if (nums[curr] == nums[prev] && nums[curr] == nums[prev - 1]) {
curr++;
} else {
prev++;
nums[prev] = nums[curr];
curr++;
}
}
return prev + 1;
}
相关文章推荐
- java对世界各个时区(TimeZone)的通用转换处理方法(转载)
- java-注解annotation
- java-模拟tomcat服务器
- java-用HttpURLConnection发送Http请求.
- java-WEB中的监听器Lisener
- Android IPC进程间通讯机制
- Android Native 绘图方法
- Android java 与 javascript互访(相互调用)的方法例子
- 介绍一款信息管理系统的开源框架---jeecg
- 聚类算法之kmeans算法java版本
- java实现 PageRank算法
- PropertyChangeListener简单理解
- c++11 + SDL2 + ffmpeg +OpenAL + java = Android播放器
- 插入排序
- 冒泡排序
- 堆排序
- 快速排序
- 二叉查找树