数据结构与算法(java版)——队列及其优化

性质

先进先出

使用场景

消耗系统,等等。

数据结构

有序列表,用数组或链表来实现。


数组

规则:先进先出.

示意图:

在这里插入图片描述

  • 图1,空数组.
  • 图2,向空数组中传入数据.从队列的尾部存数据.
  • 图3,向数组中取数据.从队列的头部取数据.

算法实现

数组


变量

  • Queue作为存放队列的数组.
  • 定义maxSize作为队列的最大容量。
  • front和rear分别记录队列前后端的下标。
  • front 随着数据的输入而改变,rear随着数据的输出而改变。

方法

  • 创建队列.
  • addQueue:rear+1,当front=rear为空。但是当尾指针rear=maxSize-1时,队列满,无法将元素插入队列。

数组优化——环形队列

变量

  • front指向队列的第一个元素,初始值为0。
  • rear变量指向队列的最后一个元素的后一个位置。因为留一个空间作为约定。初始值为0.
  • 队列满:(rear+1)maxSize==front。
  • 队列空:rear==front。
  • 队列中有效数据的个数:(rear+maxSize-front)%maxSize.

方法

  • 注意取模。
  • 添加获得数组元素有效数据的个数的方法size().

代码实现

普通队列

package queue;

import java.io.PrintStream;
import java.util.Scanner;

public class ArrayQueuedemo {
   
    public static void main(String[] args) {
   
//创建一个队列
        ArrayQueue queue= new ArrayQueue(3);
        char key=' ';//接受用户输入
        Scanner sc=new Scanner(System.in);
boolean loop=true;
while (loop){
   
    System.out.println("s(show):显示队列");
    System.out.println("e(exit):退出程序");
    System.out.println("a(add):添加数据到队列");
    System.out.println("g(get):从队列取出数据");
    System.out.println("h(head):查看队列头的数据");
    key=sc.next().charAt(0);//接受一个字符
    switch (key){
   
        case 's':
            queue.showQueue();
            break;

        case 'a':
            System.out.println("请输入一个数据:");
            int value=sc.nextInt();
            queue.addQueue(value);
            break;

        case 'g':
            try {
   
                int res=queue.getQueue();
                System.out.printf("取出的数据是:%d",res);
                System.out.println();

            }
            catch (Exception e){
   
                System.out.println
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值