/*
* ArrayUnique.java
* Version 1.0.0
* Created on 2017年12月16日
* Copyright ReYo.Cn
*/
package reyo.sdk.utils.test.array; /**
* <B>创 建 人:</B>AdministratorReyoAut <BR>
* <B>创建时间:</B>2017年12月16日 下午3:32:23<BR>
*
* @author ReYo
* @version 1.0
*/
import java.util.Arrays;
import java.util.HashSet;
import java.util.Set; /**
* ArrayUniue 数组去重的问题
*
* @author wait
*
*/
public class ArrayUnique {
/**
* 方法1 就是申请一个和nums大小一样的数组tmpNums,
* 然后遍历nums中的元素,对每个元素判断是否在tmpNums出现过,
* 如果出现过,那么就不放到新数组里面,也就是不做处理;
* 如果没有出现过,那么就把它放到新的数组里面
* 这种方法数组原来的相对顺序可以保证
* 时间复杂度是n^2和空间复杂度是n
*
* @param nums 输入需要去重的数组
* @return 返回去重后数组的长度
*/
public static int unique1(int[] nums) {
if (nums.length == 0) {
return 0;
}
int[] tmpNums = new int[nums.length];
tmpNums[0] = nums[0];
int index = 1;
for (int i = 1, len = nums.length; i < len; i++) {
int j = 0;
for (; j < index; j++) {
if (tmpNums[j] == nums[i]) {
break;
}
}
if (j == index) {
tmpNums[index++] = nums[i];
}
}
nums = tmpNums;
return index;
} /**
* 方法2 先对nums排序,排序后重复的元素一定相邻,
* 然后遍历nums,并用index来表示不重复的元素应该存放的下标,
* 如果当前遍历的元素和他的前一个元素相等,那么他是重复的,遍历下一个;
* 如果不等,说明不是重复,那么当前元素存放到数组中下标为index的地方,index++
* 这样遍历下来,不同的元素都放到元数组的前面去了。
* 这种方法,得出来的是排序过得,数组原来的相对位置改变了。
* 时间复杂度和空间复杂度都是对应排序算法的复杂度
*
* @param nums 输入需要去重的数组
* @return 返回去重后数组的长度
*/
public static int unique2(int[] nums) {
if (nums.length == 0) {
return 0;
}
Arrays.sort(nums);
int index = 1;
for (int i = 1, len = nums.length; i < len; i++) {
if (nums[i] != nums[i - 1]) {
nums[index++] = nums[i];
}
}
return index;
} /**
* 方法3 利用直接插入排序的思想,把数组分成两部分,
* 左边认为是满足要求的不重复的部分,初始为1个元素nums[0];
* 而右边是等待遍历的部分,不断遍历右边的元素。
* 同样用index来表示左边部分不重复的元素应该存放的下标
* 对于当前遍历的元素,通过第二层循环遍历左边部分0到index的元素,
* 如果有元素和当前元素相等,说明是重复的,那么不处理;
* 否则,说明是不重复,那么插入到下标index的地方,index++
* 同样,遍历下来,不重复的元素被放到前面部分。
* 这种方法没有经过排序,数组原来的相对顺序可以保证。
* 这种方法,是对方法1的改进,用本数组的前部分替代新的数组
* 时间复杂度是n^2,空间复杂度是1
*
* @param nums 输入需要去重的数组
* @return 返回去重后数组的长度
*/
public static int unique3(int[] nums) {
if (nums.length == 0) {
return 0;
}
int index = 1;
for (int i = 1, len = nums.length; i < len; i++) {
int j = 0;
for (; j < index; j++) {
if (nums[j] == nums[i]) {
break;
}
}
if (j == index) {
nums[index++] = nums[i];
}
}
return index;
} /**
* 方法4 利用Java中容器来帮助判断元素是否重复。可以使用Set Map List等
* 这里我们利用Set容器不能存放相同的元素的特性,
* 同样用index来表示不重复的元素应该存放的下标
* 当前元素如果能够成功加入到Set容器中,说明这个元素还没有重复的,
* 那么当前元素就可以放到下标index的地方,index++;
* 如果add失败,那么说明重复了,不做操作。
* 这种方法,同样是把不重复的数组放到数组的前面, 并可以保证元素的相对位置不变, 不过需要额外的Set容器的空间。
* 时间复杂度是n,空间复杂度也是n
*
* @param nums 输入需要去重的数组
* @return 返回去重后数组的长度
*/
public static int unique4(int[] nums) {
if (nums.length == 0) {
return 0;
}
Set<Integer> set = new HashSet<Integer>();
int index = 0;
for (int i = 0, len = nums.length; i < len; i++) {
if (set.add(nums[i])) {
nums[index++] = nums[i];
}
}
return index;
} /**
* printNums 打印数组的从0到length元素
*
* @param nums 输入数组
* @param length 打印长度
*/
public static void printNums(int[] nums, int length) {
for (int i = 0; i < length - 1; i++) {
System.out.print(nums[i] + " ");
}
System.out.println(nums[length - 1]);
} /**
* main 函数
*
* @param args
*/
public static void main(String[] args) {
int[] nums = { 221, 3321, 4342, 2513, 436, 263, 2163, 44, 2351, 23261, 432, 12, 3, 123, 23, 12, 3, 2, 4, 23, 1,
2312, 4, 33, 21, 31, 23 };
printNums(nums, nums.length);
int len = unique4(nums);
printNums(nums, len);
}
}

java去除数组中重复的元素方法总结的更多相关文章

  1. [转]java去除List中重复的元素

    java去除List中重复的元素 如果用Set ,倘若list里边的元素不是基本数据类型而是对象, 那么请覆写Object的boolean   equals(Object   obj)   和int  ...

  2. array_unique() - 去除数组中重复的元素值

      array_unique() 定义和用法 array_unique() 函数移除数组中的重复的值,并返回结果数组. 当几个数组元素的值相等时,只保留第一个元素,其他的元素被删除. 返回的数组中键名 ...

  3. 关于iOS去除数组中重复数据的几种方法

    关于iOS去除数组中重复数据的几种方法   在工作工程中我们不必要会遇到,在数组中有重复数据的时候,如何去除重复的数据呢? 第一种:利用NSDictionary的AllKeys(AllValues)方 ...

  4. php 去除数组中重复元素

    去除数组中重复元素, 找了下可以一下两个函数 php array_flip()与array_uniqure() $arr = array(…………) ;// 假设有数组包含一万个元素,里面有重复的元素 ...

  5. JS去除数组中重复值的四种方法

    JS去除数组中重复值的四种方法 1 /// <summary>            o[this[i]] = "";  }      }       newArr.p ...

  6. php去除数组中重复数据

    <?php /** * 去除数组中重复数据 * by www.jbxue.com **/ $input = array("a" => "green" ...

  7. Python 去除列表中重复的元素

    Python 去除列表中重复的元素 来自比较容易记忆的是用内置的set l1 = ['b','c','d','b','c','a','a'] l2 = list(set(l1)) print l2 还 ...

  8. JavaScript去除数组中重复的数字

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  9. 集合求交集 & 去除列表中重复的元素

    集合求交集: set1 = {1,2,3,4,5} set2 = {4,5,6,7,8} 交集:set3 = set1 & set2 print(ste3) #结果为{4,5} 或者ste1. ...

随机推荐

  1. JavaScript之this学习心得

    this在运行时绑定,并不是在编写时绑定,它的上下文取决于函数调用的各种条件.this既不指向自身,也不指向函数的词法作用域.this是在函数被调用时发生的绑定,指向什么完全取决于函数在哪里被调用. ...

  2. VC++一些开发心得与调试技巧

         1.如何在Release状态下进行调试 Project->Setting=>ProjectSetting对话框,选择Release状态.C/C++标签中的Category选Gen ...

  3. HTML5练习4

    1.菜单条 主要代码 <!doctype html> <html> <head> <meta charset="utf-8"> &l ...

  4. P2690 接苹果

    P2690 接苹果f[i][j][k]表示i=1或2,表示j时刻cow在哪棵树下j表示时刻k表示转移了k次如果当前第1棵树落苹果f[1][t][left]=max(f[1][t-1][left],f[ ...

  5. 002.WordPress常见插件

    Akismet Akismet 是 WordPress 官方推荐的一款 WordPress 防垃圾评论插件,也是默认已安装的插件. WP-Postviews 最好的最流行的WordPress浏览次数统 ...

  6. 《编写可维护的javascript》读书笔记(中)——编程实践

    上篇读书笔记系列之:<编写可维护的javascript>读书笔记(上) 上篇说的是编程风格,记录的都是最重要的点,不讲废话,写的比较简洁,而本篇将加入一些实例,因为那样比较容易说明问题. ...

  7. 【转】frameset 框架集使用语法,常用语后台。

    XHTML 框架概述 框架的使用可以让浏览器“分割”成多个页面显示内容,常用于如网站后台管理这些菜单项目固定,且对美观性和搜索引擎要求不高的地方. 框架的优缺点 框架方便制作栏目导航,操作各栏目时不需 ...

  8. GEEK-2018之隐藏在混乱之中的绝密情报 writeup

    题目如上 打开题目后发现,提示robots 随后提示又需要改一改名字 修改文件名为humans.txt之后发现 有个备份文件,直接访问www.zip就可以下载了 下载打开后如下: 在其中看到了unse ...

  9. 自动化运维_Ansible

    1. 前言 Ansible是自动化运维的工具,基于Python开发,实现了批量系统配置.批量程序部署.批量运行命令等功能. Ansible是基于模块工作的,ansible提供一个框架,通过模块实现批量 ...

  10. MySQL分析数据运行状态【SHOW PROCESSLIST】

    这个博文,将只是简单的记录一下,我们的数据库操作和使用中,加索引加不上去,分析的过程,其实比较简单,就是看有没有连接进程还在操作表.有的话,将其停掉(不影响业务的场景下). 今天的主角是: SHOW ...