热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

数据结构java详解_Java.数据结构.集合体系详解

I.第一部分:常见数据结构首先简单说下数据结构.什么是数据结构?数据结构就是组织数据的方式.常见的数据结构:栈,堆ÿ

I. 第一部分:常见数据结构

首先简单说下数据结构.

什么是数据结构?数据结构就是组织数据的方式.

常见的数据结构:栈,堆,树,图,数组,队列,链表.

这里主要介绍与java集合体系相关的栈、数组和链表.

特点:压栈弹栈,先进后出.

如:手枪弹夹装弹过程,最先压入的子弹在最下面;而在射击时,最先弹入枪膛的是最上面的子弹,即最后压入弹夹的子弹.

队列

特点:先进先出.

如:子弹射出的过程,先进入枪膛的子弹最先被射出.

数组

概述:用来存储同一种类型元素的容器。

特点:在内存中是连续的,每个元素都有编号(从0开始的),方便获取。但增删就比较麻烦,需要将目标位置后的所有数据前移动或后移.

查询快,增删慢.

链表

概述:把一些结点通过链子连接起来的数据结构。每个结点由地址域和数值域组成.

特点:增删快,查询慢. 增删时,只需要把所插入处的前后节点链条断开,增加或移除目标节点,速度很快。反之,查询时则需要遍历所有节点,直到找到目标节点,速度自然要慢。

II. 第二部分:Java中的Collection(集合)体系

b44cac914faa797c2f9061288a76f430.png

2.1 集合体系概览:

集合体系分为4大块:

Collection接口:

Collection是最基本集合接口,它定义了一组允许重复的对象.

它有两个子接口:List和Set.

1. List下3个实现类:ArrayList, LinkedList, Vector. List是有序的。

1.1 List接口的三个儿子的特点:

1.1.1 ArrayList:底层数据结构是数组,查询快,增删慢。线程不安全(不同步),效率高。

1.1.2 Vector:底层数据结构是数组,查询快,增删慢。线程安全,效率低。

1.1.3 LinkedList:底层数据结构是链表,增删快,查询慢。 线程不安全的,效率高。

1.2 如何来选择使用哪个仔呢?

keywords: 看需求!

step1: 看是否考虑安全? 安全, 则Vector.

step2: 如果不考虑安全,那么是查询多还是增删多?

查询多, 则ArrayList; 增删多,则LinkedList.

什么都不知道,用ArrayList。

2. Set下2个实现类:HashSet, TreeSet. Set是无序的。

Map接口:

该接口描述了从不重复的键到值的映射。Map接口用于维护键/值对.

特征:它描述了从不重复的键到值的映射.

两个重要的实现类:HashMap和TreeMap.

1.HashMap,中文叫散列表,基于哈希表实现,特点就是键值对的映射关系。一个key对应一个Value。

HashMap中元素的排列顺序是不固定的。更加适合于对元素进行插入、删除和定位。

2.TreeMap,基于红黑树实现。TreeMap中的元素保持着某种固定的顺序。更加适合于对元素的顺序遍历。

Comaprable接口:

Comparable可以用于比较的实现,实现了Comparable接口的类可以通过实现comparaTo方法从而确定该类对象的排序方式。

Iterator接口:

用于循环访问集合中的对象。

所有实现了Collection接口的容器类都有iterator方法,用于返回一个实Iterator接口的对象。

Iterator对象称作迭代器,Iterator接口方法能以迭代方式逐个访问集合中各个元素,并可以从Collection中除去适当的元素。

2.2 Collection的接口概览(List 和 Set)

2.2.1 List接口

三个子类:

ArrayList

底层数据结构是数组,查询快,增删慢。

线程不安全(不同步),效率高。

-Vector

底层数据结构是数组,查询快,增删慢。

线程安全,效率低。

特有功能:

添加:

void addElement(Object obj);

获取:

Object elementAt(int index);

Enumeration elements(); //它返回此向量的组件的枚举,类似于迭代器Iterator

boolean hasMoreElements() //类似于hasNext()

Object nextElement(); //类似于next();

-LinkedList

底层数据结构是链表,增删快,查询慢。

线程不安全的,效率高。

特有方法:

添加:

void addFirst(Object obj);//头部添加元素

void addLast(Object obj);//尾部添加元素

获取:

Object getFirst();//获取头部元素

Object getLast();//获取尾部元素

删除:

Object removeFirst();//移除头部元素

Object removeLast();//移除尾部元素

#问:以后用List体系的那个子类?

看是否考虑安全。

安全:用Vector

不安全:继续考虑是查询多还是增删多

查询多:ArrayList

增删多:LinkedList

什么都不知道,用ArrayList。

#练习题:

1.一个字符串集合ArrayList中含有如下元素:hello, world, java, hello, .net, java, php, ios, java, android,world。要求编写程序,获得一个没有重复元素的新集合。

#思路:

1、创建两个集合对象,A,B。

2、把字符串添加到集合A中。

3、遍历集合A,并且判断集合B中是否包含A集合当前遍历到的元素。

4、如果包含,不添加,如果不包含,就将该元素添加到集合B中。

5、迭代结束后,集合B中存的就是去重后的元素。

练习题

#请用LinkedList来模拟栈的数据结构。

刚我们知道栈的结构为:先进后出.

咱们可以使用LinkedList集合,对这个类进行包装来实现先进先出的效果,但不能直接使用它。

具体实现时,先往集合里添加一个新数据,add(); 取自己写类,对LinkedList进行封装:

1、需要提供添加元素的方法add() //内部封装的是:addFirst()

2、需要提供获取元素的方法get(int index) //内部封装的是:List体系的get(int index)方法

3、需要提供获取集合长度的方法size() //内部分装的是:LinkedList的size()方法

以后遇到类似的题,怎么做?

解题思路:

1、分析要模拟的数据结构的特点。

2、对可用的类进行包装,然后提供对应的方法就可以了。

2.2 Set集合

set集合的特点: 无序,唯一

2.2.1 HashSet集合

A:底层数据结构是哈希表(是一个元素为链表的数组)

B:哈希表底层依赖两个方法:hashCode()和equals()

如何保证元素唯一性?

由hashCode()和equals()保证的,先调用hashCode()在调用equals().

执行顺序:

首先比较哈希值是否相同:

若相同:

继续执行equals()方法;

-返回true:元素重复了,不添加;

-返回false:直接把元素添加到集合;

若不同:

就直接把元素添加到集合;

2.2.2 TreeSet集合

A:底层数据结构是红黑树(是一个自平衡的二叉树)

B:保证元素的排序方式

排序方法:

a:自然排序(元素具备比较性):让元素所属的类实现Comparable接口.

b:比较器排序(集合具备比较性):让集合构造方法接收Comparator的实现类对象

2.3 Map接口概览

Map也是接口,但没有继承Collection接口。该接口描述了从不重复的键到值的映射。Map接口用于维护键/值对(key/value pairs)。

特征:它描述了从不重复的键到值的映射。

两个重要的实现类:HashMap和TreeMap

1.HashMap,中文叫散列表,基于哈希表实现,特点就是键值对的映射关系。一个key对应一个Value。HashMap中元素的排列顺序是不固定的。更加适合于对元素进行插入、删除和定位。

2.TreeMap,基于红黑书实现。TreeMap中的元素保持着某种固定的顺序。更加适合于对元素的顺序遍历。

总结

|-List

有序,可重复

|--ArrayList

底层数据结构是数组,查询快,增删慢.

线程不安全,效率高.

|--Vector

底层数据结构是数组,查询快,增删慢.

线程安全,效率低.

|--LinkedList

底层数据结构是链表,查询慢,增删快.

线程不安全,效率高.

|-Set

无序,唯一

|--HashSet

底层数据结构是哈希表.

保证元素唯一性: 依赖两个方法:hashCode()和equals().

|--LinkedHashSet

底层数据结构是链表和哈希表

由链表保证元素有序

由哈希表保证元素唯一

|--TreeSet

底层数据结构是红黑树。

如何保证元素排序? 自然排序; 比较器排序.

如何保证元素唯一性的呢? 根据比较的返回值是否是0来决定.

4:针对Collection集合我们到底使用谁?

唯一么? 是:Set; 否:List.

若用Set: 排序么? 是:TreeSet; 否:HashSet. 如果知道是Set,但是不知道是哪个Set,就用HashSet. 要安全吗?是:Vector; 否:ArrayList或者LinkedList.

若用List: 查询多:ArrayList 增删多:LinkedList 如果你知道是List,但是不知道是哪个List,就用ArrayList.

如果你知道是Collection集合,但是不知道使用谁,就用ArrayList。

如果你知道用集合,就用ArrayList。

5:在集合中常见的数据结构(掌握)

ArrayXxx:底层数据结构是数组,查询快,增删慢; LinkedXxx:底层数据结构是链表,查询慢,增删快; HashXxx:底层数据结构是哈希表。依赖两个方法:hashCode()和equals(); TreeXxx:底层数据结构是二叉树。两种方式排序:自然排序和比较器排序;



推荐阅读
  • STL迭代器的种类及其功能介绍
    本文介绍了标准模板库(STL)定义的五种迭代器的种类和功能。通过图表展示了这几种迭代器之间的关系,并详细描述了各个迭代器的功能和使用方法。其中,输入迭代器用于从容器中读取元素,输出迭代器用于向容器中写入元素,正向迭代器是输入迭代器和输出迭代器的组合。本文的目的是帮助读者更好地理解STL迭代器的使用方法和特点。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 云原生边缘计算之KubeEdge简介及功能特点
    本文介绍了云原生边缘计算中的KubeEdge系统,该系统是一个开源系统,用于将容器化应用程序编排功能扩展到Edge的主机。它基于Kubernetes构建,并为网络应用程序提供基础架构支持。同时,KubeEdge具有离线模式、基于Kubernetes的节点、群集、应用程序和设备管理、资源优化等特点。此外,KubeEdge还支持跨平台工作,在私有、公共和混合云中都可以运行。同时,KubeEdge还提供数据管理和数据分析管道引擎的支持。最后,本文还介绍了KubeEdge系统生成证书的方法。 ... [详细]
  • 本文介绍了解决二叉树层序创建问题的方法。通过使用队列结构体和二叉树结构体,实现了入队和出队操作,并提供了判断队列是否为空的函数。详细介绍了解决该问题的步骤和流程。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • C++语言入门:数组的基本知识和应用领域
    本文介绍了C++语言的基本知识和应用领域,包括C++语言与Python语言的区别、C++语言的结构化特点、关键字和控制语句的使用、运算符的种类和表达式的灵活性、各种数据类型的运算以及指针概念的引入。同时,还探讨了C++语言在代码效率方面的优势和与汇编语言的比较。对于想要学习C++语言的初学者来说,本文提供了一个简洁而全面的入门指南。 ... [详细]
  • HashMap的相关问题及其底层数据结构和操作流程
    本文介绍了关于HashMap的相关问题,包括其底层数据结构、JDK1.7和JDK1.8的差异、红黑树的使用、扩容和树化的条件、退化为链表的情况、索引的计算方法、hashcode和hash()方法的作用、数组容量的选择、Put方法的流程以及并发问题下的操作。文章还提到了扩容死链和数据错乱的问题,并探讨了key的设计要求。对于对Java面试中的HashMap问题感兴趣的读者,本文将为您提供一些有用的技术和经验。 ... [详细]
  • 本文介绍了H5游戏性能优化和调试技巧,包括从问题表象出发进行优化、排除外部问题导致的卡顿、帧率设定、减少drawcall的方法、UI优化和图集渲染等八个理念。对于游戏程序员来说,解决游戏性能问题是一个关键的任务,本文提供了一些有用的参考价值。摘要长度为183字。 ... [详细]
  • 本文介绍了如何使用PHP向系统日历中添加事件的方法,通过使用PHP技术可以实现自动添加事件的功能,从而实现全局通知系统和迅速记录工具的自动化。同时还提到了系统exchange自带的日历具有同步感的特点,以及使用web技术实现自动添加事件的优势。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • Spring特性实现接口多类的动态调用详解
    本文详细介绍了如何使用Spring特性实现接口多类的动态调用。通过对Spring IoC容器的基础类BeanFactory和ApplicationContext的介绍,以及getBeansOfType方法的应用,解决了在实际工作中遇到的接口及多个实现类的问题。同时,文章还提到了SPI使用的不便之处,并介绍了借助ApplicationContext实现需求的方法。阅读本文,你将了解到Spring特性的实现原理和实际应用方式。 ... [详细]
  • Python SQLAlchemy库的使用方法详解
    本文详细介绍了Python中使用SQLAlchemy库的方法。首先对SQLAlchemy进行了简介,包括其定义、适用的数据库类型等。然后讨论了SQLAlchemy提供的两种主要使用模式,即SQL表达式语言和ORM。针对不同的需求,给出了选择哪种模式的建议。最后,介绍了连接数据库的方法,包括创建SQLAlchemy引擎和执行SQL语句的接口。 ... [详细]
  • 本文介绍了在Android开发中使用软引用和弱引用的应用。如果一个对象只具有软引用,那么只有在内存不够的情况下才会被回收,可以用来实现内存敏感的高速缓存;而如果一个对象只具有弱引用,不管内存是否足够,都会被垃圾回收器回收。软引用和弱引用还可以与引用队列联合使用,当被引用的对象被回收时,会将引用加入到关联的引用队列中。软引用和弱引用的根本区别在于生命周期的长短,弱引用的对象可能随时被回收,而软引用的对象只有在内存不够时才会被回收。 ... [详细]
author-avatar
U友50140862
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有