【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 }

你可能感兴趣的:(LeetCode)