码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构:队列


    利用数组实现一个队列。(用循环数组实现队列效率更高,后期再补充)其功能包括构造队列、队列判满、队列判空、元素入队、元素出队、获取队首元素、打印队列。


    创建一个ArrayQueue类,并声明一些后续需要用到的变量。rear是尾指针,head是头指针,size用于记录队列的大小,数组arr则用于实现队列。

    1. class ArrayQueue{
    2. private int rear;
    3. private int head;
    4. private int size;
    5. private int[] arr;
    6. //......
    7. }

    一、构造队列

    该方法负责创建一个制定大小的数组作为队列,并初始化头指针head和尾指针rear,值为-1。该处将初始值设为-1是为了后续处理方便。

    1. //构造
    2. public ArrayQueue(int maxsize){
    3. size = maxsize;
    4. arr = new int[size];
    5. rear = -1;
    6. head = -1;
    7. }

    二、判断队列是否已满

    当头尾指针相距长度为size时,则表示该队列已满。若满足判断则返回true,表示已满;否则,返回false,表示未满。

    1. //判满
    2. public boolean isFull(){
    3. return rear - head == size;
    4. }

    三、判断队列是否为空

    当头尾指针重合时(一般此时值为-1),表示已空。同上步骤,返回true或false。

    1. //判空
    2. public boolean isEmpty(){
    3. return rear == head;
    4. }

    四、元素入队

    在入队操作时,我们入参element表示需要插入队列的元素。第一步,先判断此时队列是否已满,若已满则抛出异常或者打印“队列已满”提示;如果队列未满,则将rear后移一位,将element放入数组新位置中。(rear设置为-1是为了此处操作一致。)并打印“入队成功!”提示。

    1. //入队
    2. public void addQueue(int element){
    3. if(isFull()){
    4. //throw new RuntimeException("队列已满!");
    5. System.out.println("队列已满!");
    6. return;
    7. }
    8. rear++;
    9. arr[rear] = element;
    10. System.out.println("入队成功!");
    11. }

    五、元素出队

    需要完成出队动作时,第一步也是先判断该队列是否还存在元素,如果队列为空直接抛出异常。如果不为空,则将对首元素记录在ans变量中,然后数组其他元素一次向前移动一个位置,保证队

  • 相关阅读:
    AgileConfig 1.6.0 发布 - 支持服务注册与发现
    y108.第六章 微服务、服务网格及Envoy实战 -- 可观测应用之分布式跟踪(十九)
    Android 蓝牙使用
    【Spring Boot+Vue.js+JPA+Mysql】实现前后端分离的名片系统(附源码 超详细必看 可作为大作业使用)
    有哪些常见的网络安全威胁?
    封装一个简单的table组件
    使用Objective-C和ASIHTTPRequest库进行Douban电影分析
    获取系统信息==Linux应用编程3
    OV5640 低功耗使用说明- PowerDown模式
    Spring中@Bean标注的方法是如何创建对象呢?
  • 原文地址:https://blog.csdn.net/Hokachi/article/details/127845017
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号