线性数据结构----(数组,链表,栈,队列,哈希表)

线性数据结构

  • 数组
  • 链表
    • 使用场景
  • 队列
    • 应用场景
  • 哈希表
    • 特点
    • 哈希函数,哈希值,哈希冲突
      • 键值对 Entry
    • 开放寻址法和拉链法
  • 参考文档

数组

  • 数组(Array) 是一种很常见的数据结构。由相同类型的元素组成,并且是使用一块连续的内存来存储的。

  • 在数组中 我们可以直接利用元素的索引(index)计算出该元素对应的存储地址

  • 数组的特点是:随机访问,但容量有限

      int[] arr = new int[n];
      访问:O(1)//访问特定元素
      插入/删除:O(n)//插入到数组头,或删除数组头元素--》都需要将数组中所有元素进行移动操作
    

链表

  • 有趣的理解(只是便于理解)
    可以这么理解链表

      把链表看成一个家庭关系(只查单线哈),把链表中的数据看成家庭里的人。
      
      有一天啊,来你家做人口调查
      怎么查呢?按常理--》从最年长的开始,比如:
      爷爷
      爷爷的孩子--》爸爸
      爸爸的孩子--》你
      你--》null
      
      这里,每个人,就相当于链表中的一个数据元素,
      它包括了爷爷本身 和 从爷爷出发找爸爸的指针
      同理,爸爸 也包括了它自身 和 指向你的指针
      你没有孩子,所以指针为空
      
      这就是,单链表
    
  • 链表分类(常见)

    • 单链表
    • 双向链表
    • 循环链表
    • 双向循环链表
  • 链表由一系列节点(链表中每一个元素成为节点)组成,节点在运行时动态生成,每个节点包括两个部分:

      - 数据域:存储数据元素
      - 指针域:存储下一个节点地址
    
    • 单链表
      在这里插入图片描述

    • 循环链表
      尾节点不指向null,而是指向头结点
      在这里插入图片描述

    • 双向链表
      包含两个指针,一个prev指向前一个节点,一个next指向后一个节点
      在这里插入图片描述

  • 双向循环
    在这里插入图片描述

  • 链表(LinkedList)

    • 虽然是一种线性表,但它和数组不同,它不是顺序存储的,而是使用不连续的内存空间存储数据(链表的结点一般都有后继指针next–》指向后面的元素存储位置)。
    • 因此,插入和删除操作:O(1);查找O(n)
    • 这种结构可以克服数组需要预先知道数据大小的缺点充分利用计算机的内存空间,实现灵活的内存动态管理。
    • 同时,也因此 链表不具有数组的随机读取的特点(必须知道目标位置元素的上一个元素)
  • 数组VS链表

    • 数组可以随机访问,链表不可以随机访问
    • 如果需要存储的数据元素的个数不确定,并且需要经常添加和删除数据的话,使用链表比较合适
    • 如果需要存储的数据元素的个数确定,并且不需要经常添加和删除数据的话,使用数组比较合适
    • 数组使用的是连续的内存空间,对CPU的缓存机制友好,链表则相反
    • 数组大小固定,而链表天然支持动态扩容。如果声明的数组过小,需要另外申请一个更大的内存空间放数组元素,然后将原数组拷贝进去(这个操作是比较耗时的!)

栈(Stack)就像个无顶的盒子
只允许在有序的线性数据集合的一端(称为栈顶top)进行加入数据(push)和移除数据(pop)的操作。
因而按照
后进先出
(LIFO,last in first out)的原理运作。
在栈中,push和pop的操作都发生在栈顶

在这里插入图片描述

  • 栈 常用一维数组或链表来实现,用数组实现的栈叫做顺序栈,用链表实现的栈叫做链式栈

使用场景

  • eg.实现浏览器的回退和前进功能

队列

  • 可以把队列看做是食堂打饭的队伍
    在这里插入图片描述

  • 队列(Queue)是先进先出(FIFO,first int first out)的线性表。

应用场景

当我们需要按照一定顺序来处理数据的时候,可以考虑使用队列这个数据结构。

哈希表

百科解释:

散列表(Hash
table,也叫哈希表),是根据键(Key)而直接访问在内存存储位置的数据结构。也就是说,它通过计算一个关于键值的函数,将所需查询的数据映射到表中一个位置来访问记录,这加快了查找速度。这个映射函数称做散列函数,存放记录的数组称做散列表。

特点

提炼一下:

  • 哈希表(也叫散列表)。
  • 哈希表本质是一种数据结构----》特点可以根据一个key值直接访问数据,因此查找速度快

提到数据结构,特点是查找速度快的还有什么呢?

  • 数组—》所以,Hash Table本质就是一个数组
    ???那它跟数组有什么区别呢?

哈希函数,哈希值,哈希冲突

  • 这有一个例子:

      eg.在电话表里找“王三”这个人
      - 如果是数组,怎么找呢?---》遍历
      	for(...){ if(...)... }
      - 那哈希表呢?
      我们把电话表中的数据,按照首字母进行分类
      然后,查找 ‘w’ 里面的数据
      从而,找到 “王二”
    

这里,我们把按首字母排序这个方法叫做哈希函数(散列函数)

键值对 Entry

  • 这还有个 不算例子

      我们都知道,哈希表经常存放的是一些键值对(key,value),jdk中把键值对叫做Entry。这是啥意思呢?
      就是key对应着value
      也就是value是由key通过哈希函数映射来的
      value就叫做哈希值(hash值)
    

啥玩应?

  • 这是个例子:

      eg. 王二的学生信息:002,王二
      
      我们根据之前说的,要有一个哈希函数,
      假设哈希函数的作用是 将002--》0
      那么 key = 0;value = 王二
      
      (0,王二)就是一个键值对(key,value)
      根据 0,我们可以查找出 王二 来
    

那 如何把kv对存到哈希表中呢?

	我们说了,哈希表本质还是个数组嘞
	根据 key 的值,就可以把value存到对应的位置上去

在这里插入图片描述
那这就有个问题了?

	如果 还有个学生 (007,翠花)
	key=0 value=翠花
	那不就和 王二的key冲突了吗?

这个就叫做哈希冲突(也叫做哈希碰撞)
怎么解决?

开放寻址法和拉链法

  • 开放寻址法
    在这里插入图片描述
    这里 会一直找不到空位置吗?

      不会的,对于HashMap来说,当它的增长因子(也叫负载因子),到达0.7--》比如,一共10个位置,被占了7位,那就要扩容了
      扩容 是create一个数组,是原来的2倍,然后把原数组的所有Entry都重新Hash一遍,放到新数组中
      
      重新hash 就是:把之前的数据,通过新的哈希函数计算出新的位置来存放。(因为数组扩大了,所以一般哈希函数也会有变化,就需要重新hash一遍)
    
  • 拉链法(常用)
    在这里插入图片描述

参考文档

  • github——JavaGuide项目
  • 来吧!一文彻底搞定哈希表!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/491739.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

模板方法模式(继承的优雅使用)

目录 前言 UML plantuml 类图 实战代码 AbstractRoutingDataSource DynamicDataSource DynamicDataSourceContextHolder 前言 在设计类时,一般优先考虑使用组合来替代继承,能够让程序更加的灵活,但这并不意味着要完全抛弃掉继承。 …

使用Urllib库创建第一个爬虫程序

Urllib 是 Python 的标准库,它提供了一系列用于处理 URL 的函数和类,包括发送 HTTP 请求、处理 HTTP 响应、解析 URL 等功能。可以使用 urllib 来编写简单的网络爬虫。 request:它是最基本的HTTP请求模块,可以用来模拟发送请求。只…

CUDA安装 Windows版

目录 一、说明 二、安装工具下载 三、CUDA安装 四、cuDNN配置 五、验证安装是否成功 一、说明 windows10 版本安装 CUDA ,首先需要下载两个安装包 CUDA toolkitcuDNN 官方教程 CUDA:https://docs.nvidia.com/cuda/cuda-installation-guide-micro…

面试题-Elasticsearch集群架构和调优手段(超全面)

对于Elasticsearch(ES),我了解并有经验。在我之前的公司,我们有一个相对大型的ES集群,以下是该集群的架构和一些调优手段的概述: 1. 集群架构 集群规模:我们的ES集群由15个节点组成&#xff0c…

论文篇05-论文范文-论数据访问层设计技术及其应用(2024年软考高级系统架构设计师冲刺知识点总结系列文章)

试题:论数据访问层设计技术及其应用 在信息系统的开发与建设中,分层设计是一种常见的架构设计方法,区分层次的目的是为了实现“高内聚低耦合”的思想。分层设计能有效简化系统复杂性,使设计结构清晰,便于提高复用能力和产品维护能力。一种常见的层次划分模型是将信息系统分…

MySQL之MVCC如何实现可重复读和提交读

(/≧▽≦)/~┴┴ 嗨~我叫小奥 ✨✨✨ 👀👀👀 个人博客:小奥的博客 👍👍👍:个人CSDN ⭐️⭐️⭐️:Github传送门 🍹 本人24应届生一枚,技术和水平有…

质量研发模型---V模型

质量研发模型(V模型) V模型强调软件开发的协作和速度,将软件实现和验证有机结合起来,在保证较高的软件质量情况下缩短开发周期。 通过对该模型的水平和垂直的关联和比较分析,理解软件开发和测试的关系,该模…

WebAR开发简介

WebAR 开发使企业能够以独特且高度有趣的方式向客户和员工提供信息。 它提供增强现实 (AR) 内容,人们在智能手机上将其视为视觉叠加。 然而,WebAR 可在手机的普通网络浏览器上运行,无需下载任何应用程序。 WebAR 的多种用途包括帮助零售和在…

AI大模型学习:引领智能时代的新篇章

AI大模型学习 随着人工智能技术的不断发展,大模型学习已经成为当前人工智能领域的热门话题。这项技术正在改变着我们对AI的认识和应用,同时也为未来的智能时代开启了新的篇章。 ### 什么是AI大模型学习? AI大模型学习指的是利用大规模数据…

可视化图表:柱状图,最直观的比较数据的方式。

可视化图表是一种将数据通过图形化的方式展示出来的工具,它可以帮助我们更直观地理解数据的分布、趋势和关系。其中,柱状图是最常见和常用的一种图表类型,它通过长方形的柱子来表示数据的大小。本文将介绍柱状图的定义和作用、数学原理、样式…

fl studio21.2中文版下载及使用基础教学

FL Studio 21.2.2是一款功能强大的音乐制作软件,也被广大用户称为“水果编曲”。这款软件支持简体中文和英语,适用于Windows 10/11(仅限64位)以及MacOS 10.13.6或更高版本的系统。 在FL Studio 21.2.2中,用户可以享受…

软考高级:软件构件与中间件技术概念和例题

作者:明明如月学长, CSDN 博客专家,大厂高级 Java 工程师,《性能优化方法论》作者、《解锁大厂思维:剖析《阿里巴巴Java开发手册》》、《再学经典:《Effective Java》独家解析》专栏作者。 热门文章推荐&am…

代码随想录训练营第58天 | LeetCode 739. 每日温度、​​​​​​LeetCode 496.下一个更大元素 I

目录 LeetCode 739. 每日温度 文章讲解:代码随想录(programmercarl.com) 视频讲解:单调栈,你该了解的,这里都讲了!LeetCode:739.每日温度_哔哩哔哩_bilibili 思路 ​​​​​​LeetCode 496.下一个更大元素 I 文…

深入理解TCP/IP协议:网络通信的基石

提示:本系列文章重点学习TCP/IP协议 深入理解TCP/IP协议:网络通信的基石 简介一、TCP/IP协议的基本原理二、TCP/IP协议的工作机制三、TCP面向连接建立连接:断开连接: 四、分层传输五、TCP流量控制滑动窗口机制流量控制的工作流程优…

011、获取Revit设计选项

今天来一段简单的代码,获取Revit设计选项,来说说Dynamo一个比较常用的方法: FilteredElementCollector Methods 这个方法的很有用,很多图元的获取都要通过这种方式。 我们打开API手册,直接搜索FilteredElementCol…

暴力破解笔记

1 暴力破解简介 暴力破解: 蛮力攻击,又称为穷举攻击,或暴力破解,将密码进行逐个尝试验证,直到尝试出真正的密码为止。 暴力破解是指采用反复试错的方法并希望最终猜对,以尝试破解密码或用户名或找到隐藏的…

yolov5+pyside6+登录+用户管理目标检测可视化源码

一、软件简介 这是基于yolov5目标检测实现的源码,提供了用户登录功能界面; 用户需要输入正确的用户名和密码才可以登录。如果是超级管理员,可以修改普通用户的信息,并且在检测界面的右上角显示【管理用户】按钮。 支持图片、视频、…

如何挑选品质较高的狗粮?

亲爱的狗友们,我们都知道,给狗狗选择一款高品质的狗粮是非常重要的。那么,如何在这琳琅满目的狗粮市场中挑选出最适合我们狗狗的优质狗粮呢?别担心,让我来给你支支招。 🐾 **1️⃣ 了解狗狗的营养需求** 首…

【JavaEE初阶系列】——多线程案例三——定时器

目录 🚩定时器是什么 🚩标准库中的定时器 🚩自定义定时器 🎈构造Task类 📝相对时间和绝对时间 🎈构造MyTime类 📝队列空和队列不为空 📝wait(带参)解决消耗资源问题 &#…

【面试经典150 | 动态规划】零钱兑换

文章目录 Tag题目来源解题思路方法一:动态规划 写在最后 Tag 【动态规划】【数组】 题目来源 322. 零钱兑换 解题思路 方法一:动态规划 定义状态 dp[i] 表示凑成总金额的最少硬币个数。 状态转移 从小到大枚举要凑成的金额 i,如果当前…