• 队列 java


    队列其实 所指生活中排队的现象,去商场购物,付款时需要排队, 买饭时需要排队, 好多事情都是需要排队, 排在第一位的则先处理,结束后, 后面的人都像前移动一位,在开发中也有好多这样的事情需要处理,如文件的下载,短信的发送功能, 等这些都是需要队列方式实现。好了, 废话不多说, 详情见下面代码!

    package com.fanzhang;
    
    class Queue //队列类
    {
    private int maxSize; //队列长度,由构造函数初始化
    private long[] queArray; // 队列
    private int front; //队头
    private int rear; //队尾
    private int nItems; //元素的个数
    //--------------------------------------------------------------
    public Queue(int s) // 构造函数
    {
    maxSize = s;
    queArray = new long[maxSize];
    front = 0;
    rear = -1;
    nItems = 0;
    }
    //--------------------------------------------------------------
    public void insert(long j) // 进队列
    {
    if(rear == maxSize-1) // 处理循环
    rear = -1;
    queArray[++rear] = j; // 队尾指针加1,把值j加入队尾
    nItems++; 
    }
    //--------------------------------------------------------------
    public long remove() // 取得队列的队头元素。
    {
    long temp = queArray[front++]; // 取值和修改队头指针
    if(front == maxSize) // 处理循环
    front = 0;
    nItems--; 
    return temp;
    }
    //--------------------------------------------------------------
    public long peekFront() // 取得队列的队头元素。该运算与 remove()不同,后者要修改队头元素指针。
    {
    return queArray[front];
    }
    //--------------------------------------------------------------
    public boolean isEmpty() // 判队列是否为空。若为空返回一个真值,否则返回一个假值。
    {
    return (nItems==0);
    }
    //--------------------------------------------------------------
    public boolean isFull() // 判队列是否已满。若已满返回一个真值,否则返回一个假值。
    {
    return (nItems==maxSize);
    }
    //--------------------------------------------------------------
    public int size() // 返回队列的长度
    {
    return nItems;
    }
    //--------------------------------------------------------------
    } 
    
    
    public class IntegerQueue
    {
    public static void main(String[] args)
    {
    Queue theQueue = new Queue(5); // 队列有5个元素
    
    theQueue.insert(10); // 添加4个元素
    theQueue.insert(20);
    theQueue.insert(30);
    theQueue.insert(40);
    
    theQueue.remove(); // 移除3个元素
    theQueue.remove(); // (10, 20, 30)
    theQueue.remove();
    
    theQueue.insert(50); // 添加4个元素
    theQueue.insert(60); 
    theQueue.insert(70);
    theQueue.insert(80);
    
    
    while( !theQueue.isEmpty() ) // 遍历队列并移除所有元素
    { 
    long n = theQueue.remove(); // (40, 50, 60, 70, 80)
    System.out.print(n);
    System.out.print(" ");
    }
    System.out.println("");
    } 
    } 
  • 相关阅读:
    Swagger文档项目配置
    时间格式转换和加一天操作
    Mysql 主从复制
    Nginx简单记录
    Linux Nginx
    obsidian插件Advanced Uri常用配置路径汇总
    react图片查看器插件imagesviewerreact与useRef的爱与恨
    DRF中serializer的中的模型字段解释
    Codeforces Round #787 (Div. 3)ABCD
    THUPC 2022 游记
  • 原文地址:https://www.cnblogs.com/xigua1hao/p/4802212.html
Copyright © 2020-2023  润新知