IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> Day552.队列 -数据结构和算法Java -> 正文阅读

[数据结构与算法]Day552.队列 -数据结构和算法Java

作者:recommend-item-box type_blog clearfix

队列

一、队列定义

队列是一个有序列表,可以用数组或是链表来实现。

遵循先入先出的原则。即:先存入队列的数据,要先取出。后存入的要后取出

在这里插入图片描述

二、简单队列实现

该方式会出现队列无法重复使用的问题

当我们将数据存入队列时称为”addQueue”,addQueue 的处理需要有两个步骤:思路分析

  • 将尾指针往后移:rear+1 , 当front == rear 【空】

  • 若尾指针 rear 小于队列的最大下标 maxSize-1,则将数据存入 rear所指的数组元素中,否则无法存入数据。 rear == maxSize - 1[队列满]

  • 代码实现

package com.achang.queue;

/**
 * @Author Achang
 * @Date 2022/3/7 20:38
 *  通过数组模拟队列
 *  这方式会出现数组只能使用一次就不能再使用了
 **/
public class ArrayQueue {

    private int maxSize;//数组最大容量
    private int front;//指向队列头的前一个元素
    private int rear;//队列尾部
    private int[] arr;//数据

    public ArrayQueue(int maxSize){
        this.maxSize = maxSize;
        this.front = -1;
        this.rear = -1;
        this.arr = new int[maxSize];
    }

    public boolean isFull(){
        return this.rear == this.maxSize-1;
    }

    public boolean isFree(){
        return this.front == this.rear;
    }

    public void addQueue(int n ){
        if (isFull()){
            System.out.println("队列满了");
            return;
        }
        rear++; //让rear后移
        arr[rear] = n;
    }

    public int getQueue(){
        if (isFree()){
            throw new RuntimeException("队列为空");
        }else {
            front++;
            return arr[front];
        }
    }

    public void showArr(){
        if (isFree()){
            System.out.println("队列为空,无法遍历");
            return;
        }
        for (int i : this.arr) {
            System.out.print(i);
        }
    }

    public int headQueue(){
        if (isFree()){
            throw new RuntimeException("队列为空");
        }
        return arr[front+1];
    }


    public static void main(String[] args) {
        ArrayQueue arrayQueue = new ArrayQueue(3);
    }

}

三、循环队列

在这里插入图片描述

package com.achang.queue;

/**
 * @Author Achang
 * @Date 2022/3/7 21:36
 * 通过算法 实现环形队列,解决上面一个数组只能用一次的问题
 **/
public class CircleArrayQueue {

    private int maxSize;//数组最大容量
    private int front;//指向队列头
    private int rear;//队列尾部的后一个元素
    private int[] arr;//数据

    public CircleArrayQueue(int maxSize) {
        this.maxSize = maxSize+1;
        this.front = 0;
        this.rear = 0;
        this.arr = new int[maxSize];
    }

    public boolean isFull() {
        return (this.rear + 1) % maxSize == front;
    }

    public boolean isFree() {
        return this.front == this.rear;
    }

    public void addQueue(int n) {
        if (isFull()) {
            System.out.println("队列满了");
            return;
        }
        arr[rear] = n;
        rear = (rear + 1) % maxSize;
    }

    public int getQueue() {
        if (isFree()) {
            throw new RuntimeException("队列为空");
        } else {
            int temp = arr[front];
            front = (front + 1) % maxSize;
            return temp;
        }
    }

    public void showArr() {
        if (isFree()) {
            System.out.println("队列为空,无法遍历");
            return;
        }
        for (int i = front; i < rear + size(); i++) {
            System.out.printf("arr[%d]=%d\n",i%maxSize,arr[i%maxSize]);
        }
    }

    public int size(){
        return (rear+maxSize-front)%maxSize;
    }

    public int headQueue() {
        if (isFree()) {
            throw new RuntimeException("队列为空");
        }
        return arr[front];
    }

    public static void main(String[] args) {
        CircleArrayQueue circleArrayQueue = new CircleArrayQueue(3);
    }
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-03-08 22:48:16  更:2022-03-08 22:49:47 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 13:55:12-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码