【leetcode刷题笔记】Remove Duplicates from Sorted Array II

Follow up for "Remove Duplicates":
What if duplicates are allowed at most twice?

For example,
Given sorted array A = [1,1,1,2,2,3],

Your function should return length = 5, and A is now [1,1,2,2,3].

 


题解:

设置两个变量:右边kepler和前向游标forward。如果当前kepeler所指的元素和它下一个元素相等,那么向A中存入这两个相等的元素,然后将forward置为kepeler+2,向前移动,如果碰到的元素都跟当前kepeler所指的元素相等,就忽略,否则,将kepeler移向forward所指元素,继续循环;如果当前kepeler所指的元素和它下一个元素不相等,那么就把这个元素直接加入A中,kepeler前移,继续循环。

例如题目中给的数组:1,1,1,2,2,3.

初始kepeler指向第一个1,发现kepeler+1也是一个1,就把forward置为kepeler+2=2,向前探测。探测到index为3的元素时候,发现和kepeler所指的元素不相等,就把kepeler移到索引为3处,继续上述过程,最终得到数组1,1,2,2,3.

代码如下:

 1 public class Solution {
 2     public int removeDuplicates(int[] A) {
 3         if(A == null || A.length == 0)
 4             return 0;
 5         int kepeler = 0,forward = 0;
 6         int NewSize = 0;
 7         
 8         while(kepeler < A.length){
 9             if(kepeler+1 < A.length && A[kepeler+1] == A[kepeler]){
10                 A[NewSize++] = A[kepeler];             //相同的元素有两个,都放入数组中
11                 A[NewSize++] = A[kepeler];
12                 forward = kepeler+2;
13                 while(forward < A.length && A[forward] == A[kepeler])
14                     forward++;
15                 kepeler = forward;
16             }
17             else if(kepeler < A.length){
18                 A[NewSize++] = A[kepeler];
19                 kepeler++;
20             }
21         }
22         return NewSize;
23     }
24 }
posted @ 2014-07-17 17:57  SunshineAtNoon  阅读(230)  评论(0编辑  收藏  举报