<1>删除排序数组中的重复项

题目:

  给定一个排序数组,你需要在 原地 删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。

  不要使用额外的数组空间,你必须在 原地 修改输入数组 并在使用 O(1) 额外空间的条件下完成。

解析:

  这道题的删除并不是真删,只是将不重复的元素获取移动到前面。

  因为是有序数组,所以数组排序是不需要考虑的。

  遍历一次数组,当存在arr[i-1]!=arr[i]时,arr[i-1]就是我们需要的数。

  我们在循环外设置a=0,当存在上述条件时,令arr[a]=arr[i-1],这样我们即实现了元素移动,又保存了当前元素的值,

  即我们每次只需要判断arr[i]和arr[a]是否相等就可以对整个列表数据进行判断。(列表是有序的)

 

代码:

  

package com.example.demo2;

public class Solution {


    public static int removeDuplicates(int[] nums) {
        int a = 0;
        for (int i = 1; i < nums.length; i++) {

            if (nums[i] != nums[a]) {
                a++;
                nums[a] = nums[i];
            }

        }
        return a + 1;
    }
}

 

posted @ 2020-06-16 10:00  爱李丫头  阅读(68)  评论(0编辑  收藏  举报