数据结构与算法之数组去重复
从排序数组中删除重复项
给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度。
不要使用额外的数组空间,你必须在原地修改输入数组并在使用 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;