Java学数据结构(1)——抽象数据类型ADT 表List、栈Stack和队列Qeue

news2025/1/10 11:03:49

目录

  • 引出
  • 抽象数据类型(abstract data type,ADT)
  • 表List
    • ArrayList,Vector, LinkedList
    • ArrayList手动实现与分析
    • Vector的分析(线程安全)
    • LinkedList 的手动实现与分析
  • 栈stack—后进先出
    • java中stack源码分析
    • 栈的应用:检查程序括号是否闭合
    • 栈的应用:后缀表达式
  • 队列queue—先进先出
    • Java中的queue
    • 队列的应用
    • RabbitMq队列
  • 总结

引出


1.抽象数据类型Abstract data type的概念;
2.表list,java中的ArrayList和linkedlist以及vector的分析;
3.栈stack的分析以及应用;
4.队列queue的理解,以及rabbitmq的应用;

抽象数据类型(abstract data type,ADT)

在这里插入图片描述

抽象数据类型(abstract data type,ADT)是带有一组操作的一些对象的集合。抽象数据类型是数学的抽象;在ADT的定义中没有地方提到关于这组操作是如何实现的任何解释。

诸如表、集合、图以及与它们各自的操作一起形成的这些对象都可以被看做是抽象数据类型,这就像整数、实数、布尔数都是数据类型一样。整数、实数和布尔数各自都有与之相关的操作,而抽象数据类型也是如此。

对于集合ADT,可以有像添加(add)、删除(remove)以及包含(contain)这样一些操作。当然,也可以只要两种操作并(union)和查找(ind),这两种操作又在这个集合上定义了一种不同的ADT。

在这里插入图片描述

表List

ArrayList,Vector, LinkedList

  1. ArrayList:

    • 底层数据结构是数组,使用动态数组实现。
    • 查询元素的性能较好,时间复杂度为O(1)。
    • 插入和删除元素的性能较差,需要移动其他元素,时间复杂度为O(n)。
    • 不是线程安全的,适用于单线程环境。
    • 可以通过指定初始容量来提高性能。
  2. Vector:

    • 底层数据结构也是数组,与ArrayList类似,但是Vector是线程安全的。
    • 查询、插入和删除元素的性能与ArrayList相似。
    • 由于线程安全的特性,Vector的性能通常比ArrayList略差。
    • 可以通过指定初始容量和增长因子来提高性能。
  3. LinkedList:

    • 底层数据结构是双向链表。
    • 查询元素的性能较差,需要遍历链表,时间复杂度为O(n)。
    • 插入和删除元素的性能较好,只需要修改相邻节点的指针,时间复杂度为O(1)。
    • 不是线程安全的,适用于单线程环境。
    • 适用于频繁插入和删除元素的场景。

综上所述,如果需要频繁进行查询操作,可以选择ArrayList或Vector;如果需要频繁进行插入和删除操作,可以选择LinkedList。如果需要线程安全,可以选择Vector。另外,ArrayList是最常用的一种集合类,因为它在大多数场景下具有较好的性能和灵活性。

ArrayList手动实现与分析

Java进阶(3)——手动实现ArrayList & 源码的初步理解分析 & 数组插入数据和删除数据的问题

在这里插入图片描述

Vector的分析(线程安全)

在这里插入图片描述

synchronize锁:线程安全

在这里插入图片描述

LinkedList 的手动实现与分析

Java进阶(7)——手动实现LinkedList & 内部node类的实现 & 增删改查的实现 & toString方法 & 源码的初步理解

在这里插入图片描述

栈stack—后进先出

在这里插入图片描述

栈(stack)是限制插入和删除只能在一个位置上进行的表,该位置是表的末端,叫作栈的顶(top)。栈有时又叫作LIFO(后进先出)表。

对栈的基本操作有push(进栈)和pop(出栈),前者相当于插人,后者则是删除最后插入的元素。最后插入的元素可以通过使用top例程在执行pop之前进行考查。对空栈进行的pop或top一般被认为是栈ADT中的一个错误。另一方面,当运行push时空间用尽是一个实现限制,但不是ADT错误。

在这里插入图片描述

java中stack源码分析

在这里插入图片描述

peek方法和pop方法

  • peek()方法用于查看栈顶元素,但不会将其从栈中移除。它返回栈顶元素的值,并不改变栈的状态。如果栈为空,则会抛出EmptyStackException异常。
  • pop()方法用于移除并返回栈顶元素。它将栈顶元素从栈中弹出,并返回其值。如果栈为空,则会抛出EmptyStackException异常。

这两个方法在栈的操作中非常常用。通过peek()方法,我们可以查看栈顶元素的值,而不改变栈的状态。通过pop()方法,我们可以移除并获取栈顶元素的值,同时改变栈的状态。

在这里插入图片描述

栈的应用:检查程序括号是否闭合

在这种情况下,一个有用的工具就是检验是否每件事情都能成对的程序。于是,每一个右花括号、右方括号及右圆括号必然对应其相应的左括号。序列 [ ( ) ] 是合法的,但 [ ( ] ) 是错误

这个简单的算法用到一个栈,叙述如下:

做一个空栈。读入字符直到文件结尾。如果字符是一个开放符号,则将其推入栈中。如果字符是一个封闭符号,则当栈空时报错。否则,将栈元素弹出。如果弹出的符号不是对应的开放符号,则报错。在文件结尾,如果栈非空则报错。

import java.util.Stack;

public class ParenthesesChecker {
    public static boolean checkParentheses(String code) {
        Stack<Character> stack = new Stack<>();

        for (int i = 0; i < code.length(); i++) {
            char c = code.charAt(i);

            if (c == '(' || c == '[' || c == '{') {
                stack.push(c);
            } else if (c == ')' || c == ']' || c == '}') {
                if (stack.isEmpty()) {
                    return false;
                }

                char top = stack.pop();

                if ((c == ')' && top != '(') || (c == ']' && top != '[') || (c == '}' && top != '{')) {
                    return false;
                }
            }
        }

        return stack.isEmpty();
    }

    public static void main(String[] args) {
        String code1 = "((a + b) * (c - d))";
        String code2 = "((a + b) * (c - d)";
        String code3 = "((a + b) * (c - d))}";
        String code4 = "((a + b) * (c - d))]";
        String code5 = "((a + b) * (c - d))}";

        System.out.println("Code 1 is valid: " + checkParentheses(code1));
        System.out.println("Code 2 is valid: " + checkParentheses(code2));
        System.out.println("Code 3 is valid: " + checkParentheses(code3));
        System.out.println("Code 4 is valid: " + checkParentheses(code4));
        System.out.println("Code 5 is valid: " + checkParentheses(code5));
    }
}

栈的应用:后缀表达式

后缀表达式(也称为逆波兰表达式)是一种不使用括号来表示运算符优先级的数学表达式表示方法。在后缀表达式中,运算符位于操作数之后。

例如,将中缀表达式"3 + 4 * 2 - 5"转换为后缀表达式,得到"3 4 2 * + 5 -"。

后缀表达式的计算可以通过使用栈来实现。遍历后缀表达式,当遇到操作数时,将其入栈;当遇到运算符时,从栈中弹出两个操作数进行运算,并将结果入栈。最后,栈中剩下的元素即为计算结果。

在这里插入图片描述

在这里插入图片描述

队列queue—先进先出

像栈一样,队列(queue)也是表。然而,使用队列时插入在一端进行而删除则在另一端进行。Queue(队列)是一种常用的数据结构,用于存储和操作元素。它遵循先进先出(FIFO)的原则,即最先进入队列的元素最先被取出。

在这里插入图片描述

队列的基本操作是enqueue(入队),它是在表的末端(叫作队尾(rear))插入一个元素,和dequeue(出队),它是删除(并返回)在表的开头(叫作队头(front))的元素。

Java中的queue

Java提供了多种实现Queue接口的类,常用的有以下几种:

  1. LinkedList:LinkedList类实现了Queue接口,可以用作队列的实现。它既可以作为队列使用,也可以作为双端队列使用。
  2. ArrayDeque:ArrayDeque类也实现了Queue接口,它是一个基于数组的双端队列。它可以在队列的两端进行插入和删除操作,因此可以作为队列或栈使用。
  3. PriorityQueue:PriorityQueue类实现了Queue接口,它是一个优先级队列。元素按照优先级进行排序,每次取出的元素都是优先级最高的。

这些类都实现了Queue接口,因此具有类似的方法,如offer()用于添加元素到队列尾部,poll()用于取出队列头部的元素并删除它,peek()用于查看队列头部的元素但不删除它,isEmpty()用于判断队列是否为空,size()用于获取队列的大小等。

import java.util.LinkedList;
import java.util.Queue;

public class QueueExample {
    public static void main(String[] args) {
        Queue<String> queue = new LinkedList<>();

        // 添加元素到队列尾部
        queue.offer("A");
        queue.offer("B");
        queue.offer("C");

        // 取出队列头部的元素并删除它
        String first = queue.poll();
        System.out.println("取出的元素:" + first);

        // 查看队列头部的元素但不删除它
        String peek = queue.peek();
        System.out.println("队列头部的元素:" + peek);

        // 判断队列是否为空
        boolean isEmpty = queue.isEmpty();
        System.out.println("队列是否为空:" + isEmpty);

        // 获取队列的大小
        int size = queue.size();
        System.out.println("队列的大小:" + size);
    }
}

队列的应用

当作业送交给一台行式打印机的时候,它们就以到达的顺序被排列起来。因此,被送往行式打印机的作业基本上被放到一个队列中。

事实上每一个实际生活中的排队都(应该)是一个队列。例如,在一些售票口排列的队伍都是队列,因为服务的顺序是先到先买票。

另一个例子是关于计算机网络的。有多种PC机的网络设置,其中磁盘是放在一台叫作文件服务器(file server)的机器上的。使用其他计算机的用户是按照先到先使用的原则访问文件的,因此其数据结构是一个队列。

进一步的例子如下:

  • 当所有的接线员忙不开的时候,对大公司的呼叫一般都被放到一个队列中。
  • 在大型的大学里,如果所有的终端都被占用,由于资源有限,学生们必须在一个等待表上签字登记。在终端上停留时间最长的学生将首先被强制离开,而等待时间最长的学生则将是下一个被允许使用终端的用户。

RabbitMq队列

RabbitMQ基础(1)——生产者消费者模型 & RabbitMQ简介 & Docker版本的安装配置 & RabbitMQ的helloworld + 分模块构建 & 解决大量注册案例

https://www.rabbitmq.com/

在这里插入图片描述

RabbitMQ基础(2)——发布订阅/fanout模式 & topic模式 & rabbitmq回调确认 & 延迟队列(死信)设计

在这里插入图片描述


总结

1.抽象数据类型Abstract data type的概念;
2.表list,java中的ArrayList和linkedlist以及vector的分析;
3.栈stack的分析以及应用;
4.队列queue的理解,以及rabbitmq的应用;

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android 市场的变化,影响多少开发被迫……

前言 Android 开发在2010年时&#xff0c;广受市场需要&#xff0c;那时候在一线城市很容易拿到10K的起步薪资&#xff0c;Android开发的市场空缺大概有30万左右。那时引起了大量java开发者开始学习Android开发&#xff0c;招聘市场面试要求上只要有一定java语法基础&#xff…

使用Nodejs创建简单的HTTP服务器,借助内网穿透工具实现公网访问的方法分享

文章目录 前言1.安装Node.js环境2.创建node.js服务3. 访问node.js 服务4.内网穿透4.1 安装配置cpolar内网穿透4.2 创建隧道映射本地端口 5.固定公网地址 前言 Node.js 是能够在服务器端运行 JavaScript 的开放源代码、跨平台运行环境。Node.js 由 OpenJS Foundation&#xff0…

淘宝销量采集(淘宝店的销售数据如何获取),淘宝API接口申请指南

淘宝销量采集是在网络商业流程中的一个非常重要的环节&#xff0c;可以帮助商家更好地了解市场的消费状况和竞争情况。通过对淘宝商品的销量数据进行采集与分析&#xff0c;商家可以有效地了解市场上的热销商品、竞争情况、市场价格趋势等重要信息&#xff0c;从而制定相应的营…

【DevOps视频笔记】4.Build 阶段 - Maven安装配置

一、Build 阶段工具 二、Operate阶段工具 三、服务器中安装 四、修改网卡信息 五、安装 jdk 和 maven Stage1 : 安装 JDK Stage 2 : 安装 Maven 2-1 : 更换文件夹名称 2-2 : 替换配置文件 settings.xml- 2-3 : 修改settings.xml详情 A. 修改maven仓库地址 - 阿里云 B…

RISC-V IOPMP实际用例-Andes SoC‘s Rapid-k模型

安全之安全(security)博客目录导读 2023 RISC-V中国峰会 安全相关议题汇总 说明&#xff1a;本文参考RISC-V 2023中国峰会如下议题&#xff0c;版权归原作者所有。

Tomcat漏洞复现+哥斯拉利用

Tomcat 8 启动tomcat8漏洞 将jsp木马保存到zip压缩包中&#xff0c;再修改后缀名为war上传 <%page import"java.util.*,javax.crypto.*,javax.crypto.spec.*"%><%!class U extends ClassLoader{U(ClassLoader c){super(c);}public Class g(byte []b){retu…

prometheus监控JVM(接入tomcat)

一、整合jmx_exporter及tomcat 1、 jmx_exporter下载地址 https://github.com/prometheus/jmx_exporter/releases 2、 tomcat配置文件下载地址 https://github.com/prometheus/jmx_exporter/blob/main/example_configs/tomcat.yml 3、创建tomcat_exporter目录 [rootlocalhost ~…

怎么快速生成gif?三步教你一键生成gif动图

相信大家都有使用过表情包吧&#xff0c;那么自己怎么将图片转gif动图表情包呢&#xff0c;其实很简单&#xff0c;只要使用这款在线gif制作&#xff08;https://www.gif.cn&#xff09;工具&#xff0c;就可以一键生成gif动图&#xff0c;下面一起来看看。 打开网站&#xff…

让家长自己动手,轻松查询分班信息

暑假即将结束&#xff0c;老师们面临着制作分班信息查询系统的重要任务。今天给大家推荐的这个工具对于老师们来说非常重要&#xff0c;因为它可以提供给家长和学生们方便快捷的查询服务。 分班信息查询系统可以让家长和学生们通过系统查询自己所在的班级、同班同学的信息以及班…

交通科技与管理杂志社交通科技与管理编辑部2023年第9期目录

专家论坛 黑龙江省经济高质量发展与生态环境保护耦合协调发展研究 刘降斌;祃玉帅; 1-5142 我国省际数字经济高质量发展水平综合评价研究 耿娟;毕晨曦; 6-8 振兴龙江《交通科技与管理》投稿邮箱&#xff1a;cn7kantougao163.com(注明投稿“《交通科技与管理》”) 数…

Windows怎么同时复制多个文字

Windows系统自带的剪贴板功能&#xff0c;即可优雅解决。 直接多次复制&#xff08;ctrlc,ctrlv或者鼠标操作&#xff09;&#xff0c;然后Win V 打开Windows系统自带的剪贴板功能。 像这样&#xff0c; 你就可以使用复制历史啦&#xff01;

RISC-V IOPMP实际用例-Rapid-k模型在NVIDIA上的应用

安全之安全(security)博客目录导读 2023 RISC-V中国峰会 安全相关议题汇总 说明&#xff1a;本文参考RISC-V 2023中国峰会如下议题&#xff0c;版权归原作者所有。

jvm 什么是常量池,常量池定义 class常量池

首先需要理解下Java的class文件&#xff0c;以及class文件结构&#xff1a; 1.Class文件是一组以8个字节为基础单位的二进制流&#xff0c;各个数据项目严格按照顺序紧凑地排列在文 件之中&#xff0c;中间没有任何分隔符&#xff0c;这使得整个Class文件中存储的内容几乎全部…

第四章 串 KMP算法

一、代码实现 int Index_KMP(SString s,sstring T,int next[] ){int i1, j1;while(i<s.length&&j<T.length){if(j0] ||s.ch[i]T.ch[j]){i;j;//继续比较后继字符}elsejnext[j];//模式串向右移动}if(j>T.length)return i-T.length;//匹配成功elsereturn 0; } …

1273. 删除树节点;2786. 访问数组中的位置使分数最大;889. 根据前序和后序遍历构造二叉树

1273. 删除树节点 核心思想&#xff1a;递归&#xff0c;从根节点出发&#xff0c;枚举父节点的子节点&#xff0c;如果它们的值加起来为0的话就把父亲的节点删除后剩余的数置为0&#xff0c;默认返回一个节点&#xff0c;del_remain保存的是&#xff0c;del_remain[x]表示完成…

常见的数据库备份方法,常用的数据库备份方法有哪三种

数据库作为存储和管理这些信息的核心&#xff0c;其安全性和稳定性尤为重要。因此&#xff0c;定期进行数据库备份是保护数据完整性的重要途径。下面我们就详细介绍几种常见的数据库备份方法。 1.全量备份 全备份是指备份数据库中的所有数据和元数据。这种方法通常用于开发或测…

【javaweb】学习日记Day6 - Mysql 数据库 DDL DML DQL

之前学习过的SQL语句笔记总结戳这里→【数据库原理与应用 - 第六章】T-SQL 在SQL Server的使用_Roye_ack的博客-CSDN博客 目录 一、概述 1、如何安装及配置路径Mysql&#xff1f; 2、SQL分类 二、DDL 数据定义 1、数据库操作 2、IDEA内置数据库使用 &#xff08;1&…

【Java alibabahutool】JSON、Map、实体对象间的相互转换

首先要知道三者的互转关系&#xff0c;可以先将JSON理解成是String类型。这篇博文主要是记录阿里巴巴的JSONObject的两个方法。toJSONString()以及parseObject()方法。顺便巩固Map与实体对象的转换技巧。 引入依赖 <!-- 阿里巴巴 JSON转换 以下二选一即可 没有去细研究两者…

中国电动汽车市场再添新玩家,小米启动造车梦 | 百能云芯

综合多家媒体广泛报道&#xff0c;知情人士透露&#xff0c;小米公司已获得正式批准&#xff0c;允许其踏入电动汽车制造领域。这一举措标志着这家在智能手机和物联网领域声名卓著的企业正迈向汽车制造领域&#xff0c;可谓迈出了重要的一步。按照计划&#xff0c;小米将于2024…

CTFhub-sqli注入-报错注入

用到的函数 updatexml(1&#xff0c; &#xff0c;1) concat(0x7e, ,0x7e) group_concat(目标值) right(&#xff0c;32) 1 1 1 union select updatexml(1,concat(0x7e,database(),0x7e),1) 1 union select updatexml(1,concat(0x7e,(select(group_concat(ta…