zoukankan      html  css  js  c++  java
  • 数组去重问题

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

     排序数组中删除重复项
     

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

    不要使用额外的数组空间,你必须在原地修改输入数组并在使用 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;

  • 相关阅读:
    (转帖) oracle是否归档模式及修改模式
    (转帖) Oracle实例恢复(Oracle instance recovery)
    实习第一周总结
    UML类图几种关系的总结
    表格排序
    利用js查找页面中的内链,外链
    事件机制(事件冒泡与事件捕获)
    谈 CSS 模块化
    初学后台框架总结篇二——快速了解CI框架
    初学后台框架总结篇一——学习过程
  • 原文地址:https://www.cnblogs.com/xiaocao123/p/9667848.html
Copyright © 2011-2022 走看看