数组去重问题

数据结构与算法之数组去重复

 排序数组中删除重复项
 

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

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

示例 1:

给定数组 nums = [1,1,2], 

函数应该返回新的长度 2, 并且原数组 nums 的前两个元素被修改为 1, 2。 

你不需要考虑数组中超出新长度后面的元素。

示例 2:

给定 nums = [0,0,1,1,1,2,2,3,3,4],

函数应该返回新的长度 5, 并且原数组 nums 的前五个元素被修改为 0, 1, 2, 3, 4。

你不需要考虑数组中超出新长度后面的元素。

分析思路:
1、不能创建新的数组
2、需要去掉重复的元素
3、函数需要返回新的长度
需要满足上述条件,只能在原数组中修改值,比方说原数组为array = {1,2,2,3,4},数组长度为5。假设有一个新的数组来存放新的排序结果(这个数组实际不存在),
newArray = {1,2,3,4,4}。新数组的前4位为{1,2,3,4},函数返回新的长度为4。因此需要定义一个变量size,用来统计数组中没有重复元素的个数。
 1 /**数组去重复*/
 2     public static int removeRepeted(int[] array){
 3         if(array == null && array.length == 0){
 4             return 0;
 5         }
 6         /**size:用来统计数组中没有重复的元素个数*/
 7         int size = 0;
 8         for (int i = 0; i < array.length; i++) {
 9             if (array[i] != array[size]){
10                 /**修改数组中的值*/
11                 array[++size] = array[i];
12             }
13         }
14         /**返回没有重复的个数*/
15         return size+1;
16 
17     }

具体分析如下:
int size = 0;
int[] array = {1,2,2,3};
第一步:判断array[size]与array[0]是否相等,两者相等,
int array = {1};
第二步:判断array[size]与array[1]是否相等,array[size] = 1,array[i] = 2,两者不等
int array = {1,2};
此时size++,size = 1;
第三步:判断array[size]与array[2]是否相等,array[size] = 2,array[i] = 2,两者相等
第四步:判断array[size]与array[3]是否相等,array[size] = 2,array[i] = 3,两者不等
将array[2]的值修改为array[3]的值,即array[size] = array[3]。
int array = {1,2,3,3}
此时size++,size = 2;

原文地址:https://www.cnblogs.com/xiaocao123/p/9667848.html