[数据结构】栈和队列

这篇具有很好参考价值的文章主要介绍了[数据结构】栈和队列。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

目录

1.栈

1.1概念

1.2 栈的使用

1.3.栈的模拟实现

2.队列

2.1概念

2.2队列的使用

2.3队列的模拟实现

2.4 循环队列

2.5双端队列


1.栈

1.1概念

  栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。
压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶。
出栈:栈的删除操作叫做出栈。出数据在栈顶
[数据结构】栈和队列,数据结构,java,开发语言有点类似于步枪压子弹一样,先压进去的最后在发射,最后压进去的先发射。先进后出。

[数据结构】栈和队列,数据结构,java,开发语言

1.2 栈的使用

方法 功能
Stack() 构造一个空的栈
E push(E e) 将e入栈,并返回e
E pop() 将栈顶元素出栈并返回
E peek() 获取栈顶元素
int size() 获取栈中有效元素个数
boolean empty() 检测栈是否为空

1.3.栈的模拟实现

[数据结构】栈和队列,数据结构,java,开发语言

从上图中可以看到,Stack继承了Vector,Vector和ArrayList类似,都是动态的顺序表,不同的是Vector是线程安全的。

我们使用数组来模拟实现一个栈
 

public class MyStack<E> {
    int[] array;
    int size;
    public  MyStack(){
        array=new int[3];
    }
    //压栈
    public int push(int val){
        array[size] = val;
        size++;
        return val;
    }
    //弹出栈顶元素
    public int pop(){
       int temp= peek();
       size--;
       return temp;

    }
    //查看栈顶元素
    public int peek(){
        if(empty()){
            return -1;
        }
        return array[size-1];

    }
    public boolean  empty(){
        return size==0;
    }
    //遍历
    public void display(){
        for (int i = 0; i < size; i++) {
            System.out.print(array[i]+ " ");
        }
    }
    //获取栈中元素个数
    public int size(){
        return size;
    }

}

2.队列

2.1概念

队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出FIFO(First In First Out) 入队列:进行插入操作的一端称为队尾(Tail/Rear) 出队列:进行删除操作的一端称为队头 (Head/Front)。

[数据结构】栈和队列,数据结构,java,开发语言

2.2队列的使用

在Java中,Queue是个接口,底层是通过链表实现的。
[数据结构】栈和队列,数据结构,java,开发语言

方法 功能
boolean offer(E e) 入队列
E poll() 出队列
peek() 获取队头元素
int size() 获取队列中有效元素个数
boolean isEmpty() 检测队列是否为空

注意:Queue是个接口,在实例化时必须实例化LinkedList的对象,因为LinkedList实现了Queue接口。

2.3队列的模拟实现

  我们使用单向链表来模拟实现一个队列

  首先我们思考一个问题,插入的操作很容易,但是当我们想弹出队尾元素的时候,因为是基于链表的,所以我们得知道它的前一个节点,这样才好把它给获取并删掉,如果我们采取尾插法,自然是做不到的,所以我们采取头插法。

public class MyQueue {
    class Node{
        private int val;
        private Node next;
        public Node(int val){
            this.val=val;
        }
    }
    private Node head;
    private Node last;
    private int size;
    public void offer(int data){
        Node node = new Node(data);
        if(head==null){
            head = node;
            last = node;
            size++;
        }else {
            last.next=node;
            last=node;
        }
    }
    public  int poll(){
        if(!isEmpty()){
            int tmp=head.val;
            head=head.next;
            return tmp;
        }
        return -1;
    }
    public boolean isEmpty(){
        return last==null;
    }
    public int peek(){
        if(!isEmpty()){
            return head.val;
        }
        return -1;
    }
}

2.4 循环队列

  实际中我们有时还会使用一种队列叫循环队列。如操作系统课程讲解生产者消费者模型时可以就会使用循环队列。环形队列通常使用数组实现。
[数据结构】栈和队列,数据结构,java,开发语言

2.5双端队列

 双端队列(deque)是指允许两端都可以进行入队和出队操作的队列,deque 是 “double ended queue” 的简称。
那就说明元素可以从队头出队和入队,也可以从队尾出队和入队

[数据结构】栈和队列,数据结构,java,开发语言Deque是一个Deque是一个接口,使用时必须创建LinkedList的对象

[数据结构】栈和队列,数据结构,java,开发语言

在实际工程中,使用Deque接口是比较多的,栈和队列均可以使用该接口:


Deque<Integer> stack = new ArrayDeque<>();//双端队列的线性实现
Deque<Integer> queue = new LinkedList<>();//双端队列的链式实现文章来源地址https://www.toymoban.com/news/detail-731500.html

到了这里,关于[数据结构】栈和队列的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构——Java实现栈和队列

    (1)栈是一种线性数据结构 (2)规定只能从栈顶添加元素,从栈顶取出元素 (3)是一种先进后出的数据结构(Last First Out)LIFO Java中可以直接调用方法来实现栈 如何自己写代码来实现栈呢? 先定义一个接口,方便后边进行调用 接下来来实现栈的方法,调用接口,完善方法

    2024年01月20日
    浏览(28)
  • 【数据结构】—手把手带你用C语言实现栈和队列(超详细!)

                                       食用指南:本文在有C基础的情况下食用更佳                                     🔥 这就不得不推荐此专栏了:C语言                                   ♈️ 今日夜电波:Tell me —milet                    

    2024年02月14日
    浏览(35)
  • 数据结构(C语言实现)——栈和队列的介绍及基本操作的实现(动态顺序栈+链队)

    今天我们来学习另外两个线性结构——栈和队列,栈和队列是操作受限的线性表,因此,可称为限定性的数据结构。 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端 称为栈顶,另一端称为栈底。栈中的数据元素遵守

    2023年04月19日
    浏览(29)
  • 【数据结构】栈和队列(队列篇)

    上期我们已经学习了数据结构中的栈,这期我们开始学习队列。 目录 1.队列的概念及结构 2.队列的实现 队列结构体定义 常用接口函数 初始化队列 队尾入队列 队头出队列 获取队列头部元素、 获取队列队尾元素 获取队列中有效元素个数 检测队列是否为空 销毁队列 3.循环队

    2024年02月13日
    浏览(31)
  • 栈和队列【数据结构】

    2024年02月16日
    浏览(27)
  • 数据结构--栈和队列

    栈是一种常见的数据结构,它遵循 后进先出LIFO (Last In First Out)的原则。 进行数据插入和操作的一端称为栈顶,另一端称为栈底 。 压栈 :栈的插入操作被称为压栈/进栈/入栈,入数据在栈顶。 出栈 :栈的删除操作。出数据也在栈顶; 栈可以用 数组 或者是 链表 来实现;

    2024年02月09日
    浏览(28)
  • 数据结构——栈和队列

    目录  一.前言 二.前文回顾 三.栈 3.1 栈的概念及结构 3.2 栈的实现 3.2.1 初始化函数 3.2.2 销毁函数 3.2.3 入栈函数 3.2.4 出栈函数 3.2.5 计算大小函数 3.2.6 空栈函数 3.2.7 获取栈顶函数  3.2.8 小测试 3.3 全部代码 四.栈的练习 4.1 有效的括号 五.队列 5.1队列的概念及结构 5.2 队列的实

    2024年01月25日
    浏览(29)
  • 数据结构 | 栈和队列

    … 📘📖📃本文已收录至:数据结构 | C语言 更多知识尽在此专栏中! 栈(Stack) 又名堆栈,它是一种运算受限的线性表,限定仅在表尾进行插入和删除操作的线性表。 队列(Queue) 也是一种特殊的线性表,特殊之处在于它只允许在表的前端(Front)进行删除操作,而在表的

    2024年01月23日
    浏览(30)
  • 数据结构:栈和队列

    朋友们、伙计们,我们又见面了,本期来给大家解读一下栈和队列方面的相关知识点,如果看完之后对你有一定的启发,那么请留下你的三连,祝大家心想事成! C 语 言 专 栏:C语言:从入门到精通 数据结构专栏:数据结构 个 人 主 页 :  stackY、 目录 前言:  1.栈 1.1栈的

    2024年02月06日
    浏览(26)
  • 数据结构【栈和队列】

    一、栈 1.定义:只允许一端进行插入和删除的线性表,结构与手枪的弹夹差不多,可以作为实现递归函数(调用和返回都是后进先出)调用的一种数据结构; 栈顶:允许插入删除的那端; 栈底:固定的,不允许插入或删除; 空栈:不含元素; 2.特点:后进先出; 3.操作:入

    2024年02月15日
    浏览(28)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包