我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java中怎么删除数组中的重复元素

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java中怎么删除数组中的重复元素

这篇文章将为大家详细讲解有关Java中怎么删除数组中的重复元素,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

问题:比如我有一个数组(元素个数为0哈),希望添加进去元素不能重复。

拿到这样一个问题,我可能会快速的写下代码,这里数组用ArrayList.

private static void testListSet(){          List<String> arrays = new ArrayList<String>(){              @Override             public boolean add(String e) {                  for(String str:this){                      if(str.equals(e)){                          System.out.println("add failed !!!  duplicate element");                          return false;                      }else{                          System.out.println("add successed !!!");                      }                  }                  return super.add(e);              }          };                  arrays.add("a");arrays.add("b");arrays.add("c");arrays.add("b");          for(String e:arrays)              System.out.print(e);      }

这里我什么都不关,只关心在数组添加元素的时候做下判断(当然添加数组元素只用add方法),是否已存在相同元素,如果数组中不存在这个元素,就添加到这个数组中,反之亦然。这样写可能简单,但是面临庞大数组时就显得笨拙:有100000元素的数组天家一个元素,难道要调用100000次equal吗?这里是个基础。

问题:加入已经有一些元素的数组了,怎么删除这个数组里重复的元素呢?

大家知道java中集合总的可以分为两大类:List与Set。List类的集合里元素要求有序但可以重复,而Set类的集合里元素要求无序但不能重复。那么这里就可以考虑利用Set这个特性把重复元素删除不就达到目的了,毕竟用系统里已有的算法要优于自己现写的算法吧。

public static void removeDuplicate(List<People> list){     HashSet<People> set = new HashSet<People>(list);     list.clear();     list.addAll(set);  }   ivate static People[] ObjData = new People[]{      new People(0, "a"),new People(1, "b"),new People(0, "a"),new People(2, "a"),new People(3, "c"),  };
public class People{      private int id;      private String name;            public People(int id,String name){          this.id = id;          this.name = name;      }            @Override     public String toString() {          return ("id = "+id+" , name "+name);      }        }

上面的代码,用了一个自定义的People类,当我添加相同的对象时候(指的是含有相同的数据内容),调用removeDuplicate方法发现这样并不能解决实际问题,仍然存在相同的对象。那么HashSet里是怎么判断像个对象是否相同的呢?打开HashSet源码可以发现:每次往里面添加数据的时候,就必须要调用add方法:

      @Override      public boolean add(E object) {           return backingMap.put(object, this) == null;       }

这里的backingMap也就是HashSet维护的数据,它用了一个很巧妙的方法,把每次添加的Object当作HashMap里面的KEY,本身HashSet对象当作VALUE。这样就利用了Hashmap里的KEY***性,自然而然的HashSet的数据不会重复。但是真正的是否有重复数据,就得看HashMap里的怎么判断两个KEY是否相同。

        @Override public V put(K key, V value) {  390         if (key == null) {  391             return putValueForNullKey(value);  392         }  393   394         int hash = secondaryHash(key.hashCode());  395         HashMapEntry<K, V>[] tab = table;  396         int index = hash & (tab.length - 1);  397         for (HashMapEntry<K, V> e = tab[index]; e != null; e = e.next) {  398             if (e.hash == hash && key.equals(e.key)) {  399                 preModify(e);  400                 V oldValue = e.value;  401                 e.value = value;  402                 return oldValue;  403             }  404         }  405   406         // No entry for (non-null) key is present; create one  407         modCount++;  408         if (size++ > threshold) {  409             tab = doubleCapacity();  410             index = hash & (tab.length - 1);  411         }  412         addNewEntry(key, value, hash, index);  413         return null;  414     }

总的来说,这里实现的思路是:遍历hashmap里的元素,如果元素的hashcode相等(事实上还要对hashcode做一次处理),然后去判断KEY的eqaul方法。如果这两个条件满足,那么就是不同元素。那这里如果数组里的元素类型是自定义的话,要利用Set的机制,那就得自己实现equal与hashmap(这里hashmap算法就不详细介绍了,我也就理解一点)方法了:

public class People{      private int id; //      private String name;            public People(int id,String name){          this.id = id;          this.name = name;      }            @Override     public String toString() {          return ("id = "+id+" , name "+name);      }           public int getId() {          return id;      }       public void setId(int id) {          this.id = id;      }       public String getName() {          return name;      }       public void setName(String name) {          this.name = name;      }       @Override     public boolean equals(Object obj) {          if(!(obj instanceof People))              return false;          People o = (People)obj;          if(id == o.getId()&&name.equals(o.getName()))              return true;          else             return false;      }            @Override     public int hashCode() {          // TODO Auto-generated method stub          return id;          //return super.hashCode();      }  }

关于Java中怎么删除数组中的重复元素就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java中怎么删除数组中的重复元素

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java中怎么删除数组中的重复元素

这篇文章将为大家详细讲解有关Java中怎么删除数组中的重复元素,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。问题:比如我有一个数组(元素个数为0哈),希望添加进去元素不能重复。拿到这样一个问
2023-06-17

PHP数组中的重复元素怎么删除

这篇文章主要介绍“PHP数组中的重复元素怎么删除”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“PHP数组中的重复元素怎么删除”文章能帮助大家解决问题。一、使用array_unique()函数去重PH
2023-07-06

python怎么删除数组中重复的元素

可以通过使用set()函数或者使用列表推导式来删除数组中的重复元素。方法一:使用set()函数```pythona = [1, 2, 3, 3, 4, 5, 5]b = list(set(a))print(b)```输出:```[1, 2,
2023-08-19

Java中怎么删除ArrayList的重复元素

Java中怎么删除ArrayList的重复元素,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。方法1:使用HashSet删除ArrayList中重复的元素在该方法
2023-06-17

c语言怎么删除数组中重复元素

删除数组中重复元素的方法可以分为两种:使用额外的空间:创建一个新数组,遍历原数组,将不重复的元素存入新数组。将新数组复制回原数组。int removeDuplicates(int arr[], int n) {if (n == 0 ||
c语言怎么删除数组中重复元素
2024-03-01

php如何删除数组中重复元素

这篇文章给大家分享的是有关php如何删除数组中重复元素的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。php删除数组中重复元素的方法:首先创建一个PHP示例文件;然后通过“function delmember(&$
2023-06-08

php如何删除数组中重复的元素值

这篇文章将为大家详细讲解有关php如何删除数组中重复的元素值,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。php删除数组中重复值的方法:1、使用array_unique()函数,语法“array_uniq
2023-06-14

怎么在java中删除数组元素作

怎么在java中删除数组元素作?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。Java是什么Java是一门面向对象编程语言,可以编写桌面应用程序、Web应用程序、
2023-06-14

java怎么删除数组中的某个元素

在Java中,数组的长度是固定的,无法直接删除元素。但是可以通过创建一个新的数组,并将要删除的元素排除在外来实现删除元素的效果。以下是一个示例代码,演示如何删除数组中的某个元素:```javapublic static int[] remo
2023-08-09

怎么实现PHP删除数组重复元素

这篇文章主要为大家展示了“怎么实现PHP删除数组重复元素”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“怎么实现PHP删除数组重复元素”这篇文章吧。我们在实际操作PHP代码的过程中,经常会遇到数组
2023-06-17

java怎么删除数组元素

要删除数组中的元素,可以使用以下步骤:创建一个新数组,大小比原数组小1。使用循环遍历原数组,并将不需要删除的元素复制到新数组中。返回新数组作为结果。下面是一个示例代码:public static int[] deleteElement
2023-10-27

php如何删除二维数组中重复的元素

这篇文章主要介绍了php如何删除二维数组中重复的元素,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。php删除二维数组中重复的元素的方法:首先创建一个PHP示例文件;然后通过“
2023-06-20

PHP中怎么删除数组中的元素

本文小编为大家详细介绍“PHP中怎么删除数组中的元素”,内容详细,步骤清晰,细节处理妥当,希望这篇“PHP中怎么删除数组中的元素”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、删除单个元素在PHP中,删除数组中
2023-07-05

Golang怎么删除数组中的元素

Golang可以通过创建一个新的切片的方法来删除数组中的元素。详细介绍:1、判断索引是否越界;2、创建一个新的切片;3、拷贝删除元素后的数据到新的切;4、创建一个数组;5、删除索引为2的元素;6、输出结果即可。本教程操作系统:windows
Golang怎么删除数组中的元素
2023-12-12

C# 中怎么删除数组元素

今天就跟大家聊聊有关C# 中怎么删除数组元素,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。具体如下:using System;using System.Collections.Gen
2023-06-20

PHP怎么删除数组中元素

这篇文章主要讲解了“PHP怎么删除数组中元素”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“PHP怎么删除数组中元素”吧!删除数据中的一个元素如果你想删除数组中的一个元素,你可以使用 unse
2023-06-27

php如何删除数组重复元素

本文小编为大家详细介绍“php如何删除数组重复元素”,内容详细,步骤清晰,细节处理妥当,希望这篇“php如何删除数组重复元素”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。方法1:用array_unique()函数
2023-07-04

python怎么删除矩阵中重复的元素

要删除矩阵中重复的元素,可以使用嵌套循环和条件判断来实现。以下是一个示例代码:```pythonmatrix = [[1, 2, 3], [4, 5, 2], [6, 7, 8], [1, 2, 3], [4, 5, 2]]# 创建一个空列
2023-08-19

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录