数组模拟队列
创始人
2024-05-13 17:39:38
0

队列

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

队列遵循先进先出的原则,也就是说先进队列的数据,要先出队列

数组模拟队列

  • 队列的本身是有序的列表,如果使用数组的结构来存储队列的数据,那么该队列是有一个最大容量,我们称为maxSize

  • 因为队列他有输入和输出,输入输出分别从前后端来处理,因此需要两个变量front和rear分别记录队列的前后端的下标,front随着数据的输出而改变,rear随着数据的输入而改变

存入队列(addQueue)

当我们将数据存入到对列时,称为addQueue,存入时需要两个步骤:

  • 将尾指针往后移:rear+1,特别注意:当front==rear时,我们认为队列为空

  • 如果rear小于队列的最大小标maxSize-1,那么数据就可以存入到rear所指的数组元素中,否则无法存入数据

  • 当rear=maxSize-1时,我们认为队列已经满了。

代码实现

// 使用数组模拟一个队列-编写一个ArrayQueue类
static class ArrayQueue{private int maxSize;// 队列的最大容量private int front; // 队列头private int rear;// 队列尾private int[] arr;// 数组用于,模拟队列
​// 创建队列构造器public ArrayQueue(int arrMaxSize){maxSize=arrMaxSize;arr=new int[maxSize];front=-1;rear=-1;}
​// 判断队列是否满public boolean isFull(){return rear==maxSize-1;}
​// 判断队列是否为空public boolean isEmpty(){return front==rear;}
​// 添加数据到队列public void addQueue(int val){// 判断队列是否满if (isFull()){throw new RuntimeException("队列已满,无法添加元素");}rear++;arr[rear]=val;}
​// 获取队列数据,出队列public int getQueue(){// 判断队列是否为空if (isEmpty()){throw new RuntimeException("队列为空");}front++;return arr[front];}
​// 显示队列所有的数据public void showQueue(){if (isEmpty()){System.out.println("队列为空,没有数据");return;}for (int i = 0; i < arr.length; i++) {System.out.println(arr[i]);}}
​// 显示队列头元素public int peek(){// 判断if (isEmpty()){throw new RuntimeException("队列为空");}return arr[front+1];}}

这个方法是对以上我们写的队列方法的一个测试

public static void main(String[] args) {// 创建一个队列ArrayQueue arrayQueue = new ArrayQueue(3);// 添加数据arrayQueue.addQueue(3);arrayQueue.addQueue(1);arrayQueue.addQueue(2);// 显示所有元素arrayQueue.showQueue();//出队列(结果是最开始进入队列的元素3)System.out.println(arrayQueue.getQueue());//获取头元素(由于我们前面进行了一次出队列,所以这里我们的头元素就是1)System.out.println(arrayQueue.peek());arrayQueue.addQueue(4);// 报异常 java.lang.RuntimeException: 队列已满,无法添加元素
}

问题

这里我们发现,明明已经把元素3队列了,为什么我们再次加元素4反而报了异常,说我们队列已满,这里就是我们此次构造的队列的复用性不够,当我们在进行出队列等方法时,我们的头指针和尾指针也在移动,这就导致我们前面已经用过的位置 虽然没有了元素,当他的位置还在占用,所以其复用性不够

相关内容

热门资讯

不为人知的我初中作文(推荐3... 不为人知的我初中作文 篇一我内心的小宇宙每个人都有一个内心的世界,那是一个只属于自己的空间。而我,作...
父亲的“雪花”初二作文【精彩... 父亲的“雪花”初二作文 篇一父亲的“雪花”我叫李明,今年初二。今天,我想给大家讲一个关于我的父亲的故...
游记作文600字初二【通用6... 游记作文600字初二 篇一:探索之旅这个寒假,我和家人一起去了福建。福建是一个风景优美的省份,有着许...
观奥运会闭幕式有感-初二【精... 观奥运会闭幕式有感-初二 篇一观奥运会闭幕式有感今年的奥运会闭幕式让我感受到了无比的激动和自豪。作为...
生活.人生-初二作文【优质3... 生活.人生-初二作文 篇一我对生活的理解生活是一种独特的体验,它是我们与世界互动的方式。对我而言,生...
八年级数学相似多边形的周长比... 八年级数学相似多边形的周长比和面积同步检测题 篇一相似多边形是初中数学中的重要概念之一,它们在几何学...
初二周记(精选6篇) 初二周记 篇一这一周对我来说是非常充实而有意义的一周。在这周里,我经历了许多新的事情,学到了很多新的...
就这样埋下一颗种子中考优秀作... 就这样埋下一颗种子中考优秀作文 篇一标题:勤奋是成功的关键作文:勤奋是成功的关键。这是一个被无数成功...
初二游记作文600字 初二游记作文600字(精选15篇)  在学习、工作、生活中,大家对作文都不陌生吧,借助作文人们可以反...
不舍又如何也无可奈何作文85... 篇一:不舍又如何也无可奈何不舍又如何也无可奈何作文850字 篇一不舍又如何也无可奈何,这是人们常常会...
议论文常见题型及答题规律【精... 议论文常见题型及答题规律 篇一议论文是高中语文考试中常见的题型之一,考查学生的辨析和论证能力。在备考...
猪头照片初二作文(经典3篇) 猪头照片初二作文 篇一:头脑的智慧近日,一张猪头照片在网络上引起了广泛的讨论和热议。这张照片中,一只...
初二作文学游泳【精彩6篇】 初二作文学游泳 篇一游泳是一项非常好的运动,不仅可以锻炼身体,而且还可以增强自己的水性。作为初二的学...
中考语文作文万能开头 中考语文作文万能开头  在日常学习、工作和生活中,大家总少不了接触作文吧,作文根据体裁的不同可以分为...
中考作文范文小标题河南【经典... 中考作文范文篇一:河南的美景与文化魅力河南位于中国中部,是一个历史悠久、文化底蕴深厚的省份。它不仅有...
超越自己中考满分作文(经典6... 超越自己中考满分作文 篇一超越自己中考作文是考生们最为重视的一项考试,它不仅能够展现考生的语言表达能...
成长类中考满分作文(推荐3篇... 成长类中考满分作文 篇一:《人生的成长之路》人生的成长之路,就像一条曲折而又漫长的山路,充满了各种挑...
2022浙江中考作文范文【推... 2022浙江中考作文范文 篇一题目:我的梦想职业假设你是一名初中生,请你写一篇短文描述一下你的梦想职...
关于中考满分作文附点评【经典... 关于中考满分作文附点评 篇一中国传统节日中秋节中秋节是中国传统的重要节日之一,时间在农历八月十五。人...
教师期中考试成绩分析与反思(... 教师期中考试成绩分析与反思 篇一在教师的职业生涯中,期中考试成绩的分析与反思是提高教学质量和学生学习...