首页 > 编程语言 >Java集合

Java集合

时间:2023-06-20 17:56:01浏览次数:38  
标签:Set Java LinkedList ArrayList 元素 集合 复杂度

java有什么集合?

集合的概念:用于存储数据的数据类统称为集合。
java的集合可以分两种,Collection和Map。它们都是java集合框架的接口。

  • Collection
    表示一组对象的集合。常用实现类:
    • List
      List是一种有序可重复的集合,常见的List实现类有ArrayListLinkedList
      ArrayList和LinkedList的区别:

      ArrayList LinkedList
      底层实现机制 采用动态数组数据结构 采用双向链表的数据结构
      插入和删除操作 在插入和删除时需要移动其他元素位置,时间复杂度是O(n) 在插入和删除时只需要修改指针的指向,因此时间复杂度为O(1)
      随机访问操作 可以通过下标直接访问元素,时间复杂度是O(1) 需要从头开始遍历,时间复杂度是O(n)

      综上所述,当需要频繁插入和删除元素时,LinkedList比ArrayList更为适合;当需要频繁随机访问元素时,ArrayList比LinkedList更为适合。

    • Set
      Set是一种不允许重复元素的集合,元素无序。常见的Set实现类有HashSet和TreeSet。

    • Queue
      用于表示按照一定顺序排列的元素集合。Queue提供了各种各样的方法。可以实现元素的入队和出队操作。

  • Map
    表示一组键值对的集合,可以通过键来访问值,每个键对应一个唯一的值,但键的集合不保证顺序和唯一性。常见的Map实现类有HashMap和TreeMap。

Java什么情况下用什么集合?

  1. 如果需要大量的查找使用ArrayList,因为数组能够随机访问,效率高。
  2. 如果存储的集合有先进先出的特点,则使用Queue。
  3. 如果数据是一对一的,使用Map。
  4. 如果要求数据不重复,使用Set。

标签:Set,Java,LinkedList,ArrayList,元素,集合,复杂度
From: https://www.cnblogs.com/iceweiop/p/17494216.html

相关文章

  • bzoj 2839. 集合计数 二项式反演
    集合计数设fi表示恰好交集为k的方案数。设gi表示交集至少为k的方案数。\(g_i=\sum_{j=i}^{n}C(j,i)f_j\)由二项式反演得:\(f_k=\sum_{i=k}^{n}(-1)^{i-k}C(i,k)g_i\)考虑\(g_i\)的求出,钦定\(i\)个数必选那么剩下\(n-i\)个数每个数可选可不选\(2^{n-i}\)但这道题我们选出的......
  • Java类属性第二个字母大写问题,请求参数设置不上,返回参数小写
     其实这个问题几年前就遇到过,也解决了,但是最近又看到项目中有人这么用,就想起来了,写在这里,给自己也给大家提个醒。在Java中,如果类的某个属性第二个字母是大写,比如:nToken,这样的属性一定要自己手动生成getter和setter方法。如果使用lombok的@Data注解,它默认生成的getter和setter......
  • js加密与java解密的RSA(公钥/私钥)算法
    前言:公司用的加密算法是对称密钥加密算法,服务器上的公钥与客户端的私钥都是相同的,如果不小心泄露或者通过反编译软件把客户端重新编译就会泄露密钥,这样加密后的数据就不安全了。商量使用非对称密钥RSA来解决这种问题,非对称密钥分为公钥和私钥,公钥可以公开给客户端分发给所有......
  • daka:p java
    终于搞定eclipse了用eclipse编译输出“helloworld!” 感觉比之前方便了许多,终于不用cmd了学习了一下Java的基础语法,感觉在数据类型上与C并没有太大的差异。 ......
  • Java GUI 体系
    类别基于Java的图形库最主要的有三种,它们分别是:AWT:抽象窗口工具包Swing:基于对AWT进行的改进而诞生的组件库SWT/JFace:IBM在研发Eclipse平台而退出的组件库起源在早期JDK1.0发布时,Sun公司就为GUI开发提供了一套基础类库,这套类库被称为AWT(AbstractWindow......
  • JavaScript(05): 正则表达式
    当检索某个文本的时候,我们可能需要一种模式来描述被检索的内容,在这种情况下就可以考虑使用正则表达式。正则表达式可以定义一种模式,这种模式可能是一个简单的字符、也可能是一个非常复杂的字符串,通常被用于解析、格式检查、替换等。关于正则表达式的具体内容可以参考以下链接,本文只......
  • JavaScript(02): ECMAScript基础
    ECMAScript提供了实现通用程序设计任务必需的JavaScript的语法、运算符和基本对象。1.语法ECMAScript借用了Java、C等语言的语法,对于熟悉这些语言的开发者掌握ECMAScript的语法应该是非常容易的。区分大小写变量是弱类型:定义变量时只用var关键字并且可以将变量初始化为任意值每行......
  • Java面试题集(136-150)
    Java程序员面试题集(136-150)摘要:这一部分主要是数据结构和算法相关的面试题目,虽然只有15道题目,但是包含的信息量还是很大的,很多题目背后的解题思路和算法是非常值得玩味的。136、给出下面的二叉树先序、中序、后序遍历的序列?答:先序序列:ABDEGHCF;中序序列:DBGEHACF;后序序列:DGHEBFCA。补......
  • Java面试题集(131-135)
    131、请对以下JavaEE中的名词进行解释答:容器:容器为JavaEE应用程序组件提供了运行时支持。容器提供了一份从底层JavaEEAPI到应用程序组件的联合视图。JavaEE应用程序组件不能直接地与其它JavaEE应用程序组件交互。它们通过容器的协议和方法来达成它们之间以及它们与平台服......
  • Java面试题集(116-135)
    Java程序员面试题集(116-135)摘要:这一部分讲解基于Java的Web开发相关面试题,即便在Java走向没落的当下,基于Java的Web开发因为拥有非常成熟的解决方案,仍然被广泛应用。不管你的Web开发中是否使用框架,JSP和Servlet都是一个必备的基础,在面试的时候被问到的概率还是很高的。116、说出Servl......