数组队列
数组有固定的长度,里面放置的数据也都是固定的一个类型,
当不能确定需要的长度时,实例化数组时的长度可能不够用,又或者太大造成空间浪费,
因此,我们需要一个更加灵活的东西来存储东西,
它的长度可以随着需求变化,里面存放的内容也可以多种多样。
这就是队列
队列在本质上也是一种数组,但它是活的,可变程度很大。
队列里面可以写多种方法对其进行添加,移除等多种操作。
为了让队列里可以存储多种不同类型的数据,在定义队列类中的数组类型 时可以这样。
private Object[] array = new Object[0];
这就使得任何类型的内容都可以存入该队列的数组中。
但是,有些时候使用队列只想要存入某种特定类型的数据,这时是否要重写一个队列,
在其中定义一个你想要的数据类型的数组呢?
不用这么麻烦。
/** * 队列类 * @param args */ public class Arraylist<E> { private int size = 0; private Object[] array = new Object[0]; // 添加新元素 public void add(E e) { // 定义一个比原数组长一个单位的新数组array1 Object array1[] = new Object[size + 1]; // 把原数组中的元素传给新数组 for (int i = 0; i < size; i++) { array1[i] = array[i]; } // 把新元素添加给新数组的最后一个位置 array1[size] = e; // 让原数组指向新数组 size++; array = array1; } // 删除,根据下标 public void delete(int n) { if (n >= 0 && n < size) { // 定义一个比原数组短一个单位的新数组array1 Object array2[] = new Object[size - 1]; // 把被删除元素前的元素原样传给新数组 for (int i = 0; i < n; i++) { array2[i] = array[i]; } // 把被删除元素后的元素向前移动一位传给新数组 for (int i = n; i < size - 1; i++) { array2[i] = array[i + 1]; } // 数组元素个数减少 size--; // 让原数组指向新数组 array = array2; } } //得到对象,根据下标 public E gete(int n){ if(n>=0&&n<getsize()){ E e=(E) array[n]; return e; } return null; } // 得到数组元素个数 public int getsize() { return size; } }
这样写好队列之后,想要使用队列时,只需要在初始化的时候这样:
public Arraylist<Chess> arrc = new Arraylist();
在尖括号里表明你想存的数据类型就可以啦~
很方便吧。
相关推荐
队列是一种先入先出的数据结构(FIFO),只允许在前端(front)删除,在后端(rear)插入。容量为capacity大小的内存,只能存capacity-1的元素,其中rear的位置始终为空。 本文实现的队列,功能如下: 1 获取元素内容 ...
普通队列 1)将尾指针往后移:rear+1,当front==rear【空】 2)若尾指针rear小于队列的最大下标maxSize-1,则将数据存入rear所指的数中组元素中,否则无法存入数据。rear==maxSize-1[队列满] 环形队列 1)front变量的...
### 循环链表队列与循环数组队列的代码实现解析 在计算机科学中,队列是一种重要的数据结构,遵循先进先出(FIFO)原则。队列可以使用多种方式实现,包括链表和数组。本文将深入探讨两种队列实现方式:循环链表队列...
此程序使用数组队列来存储温度数据,并在队列中保持固定数量的最新测量值。当新的温度读数到来时,如果队列已满,最旧的数据会被新数据替换。此外,程序提供了一个函数来计算队列中最新数据的平均值。 主要功能点:...
在Java中,我们可以使用数组来实现优先队列。这篇文章将探讨如何利用数组实现优先队列,并通过提供的`PriorityQ.java`文件来深入理解其实现原理。 1. **优先队列基本概念** 优先队列是一种数据结构,它维护了一个...
学习数据结构过程中,亲自在VC++上编译通过的使用数组实现队列的源代码,与大家共享。
在普通数组队列中,一旦队列满或空,需要进行数组的重新分配,而循环队列则避免了这个过程,提升了性能。 在编程语言中,如C、C++、Java或Python,我们可以用不同的方式实现数组循环队列。例如,在C++中,可以定义...
Java数组队列是一种基于数组实现的线性数据结构,它遵循先进先出(FIFO,First In First Out)的原则。在Java中,数组队列通常用于处理数据的顺序处理,例如任务调度、消息传递等场景。以下是关于Java数组队列的一些...
### 队列数组实现 #### 概述 在计算机科学中,队列是一种非常基本的数据结构,它遵循先进先出(FIFO)的原则。队列可以被用来解决多种问题,比如任务调度、缓存管理等。队列可以通过多种方式实现,其中一种常见的...
本文主要探讨了如何利用数组的特性,特别是`push`、`shift`方法实现队列的先进先出(FIFO)原则,以及`forEach`方法在数组操作中的应用和注意事项。 ### 数组与队列 在JavaScript中,数组天生支持队列的操作。`...
为了实现队列操作,数组队列通常需要两个额外的变量来跟踪队头和队尾。添加元素时,如果队列已满,则需要进行扩容操作;移除元素时,如果队列为空,会抛出异常。这种基于数组的队列虽然在空间效率上比链表实现的队列...
以下是一个使用C++模板类实现的循环数组队列: ```cpp template class MyQueue { private: struct myq { int head, rear; T* ele; }; myq* q; const int Max; public: // 构造函数 MyQueue() { q = new ...
由数组实现队列,包括队列的创建、入队和出队。通过打印显示出队的结果。正在学习数据结构的童鞋可以参考。
**泛型循环队列**,也称为环形队列,利用数组的循环特性,使得队列的首尾可以无缝连接。这种队列在处理大量数据流时有更高的效率,因为它避免了数组的动态扩展和收缩。在C#中,我们可以通过自定义类来实现泛型循环...
数组队列是另一种基于数组的数据结构,它遵循“先进先出”(FIFO)原则。你可以使用`enqueue`方法在队尾添加元素,`dequeue`方法从队头移除元素,同时支持`size`和`isEmpty`等操作。 4. **单链表(SLL)**: ...
在PHP中,实现队列的功能通常会借助数组及其内置函数来模拟队列的基本行为。队列是一种先进先出(First In First Out, FIFO)的数据结构,类似于现实生活中的排队等候系统,如银行的排号机,最先排在队伍中的人会...
### 基于数组的队列 #### 概述 本篇内容介绍了一种改进的基于数组实现的队列结构,特别之处在于引入了一个`tag`标记来优化队列的操作判断逻辑,使得队列在判空(判断是否为空)与判满(判断是否已满)时更加高效...
循环数组实现队列 队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作。队列的操作受限制,和栈一样,它是一种操作受限制的线性表。进行插入操作的...
配套代码讲解:https://blog.csdn.net/songchuwang1868/article/details/90200251 ...同步队列-无锁队列-循环数组无锁队列 同步队列-无锁队列-循环数组无锁队列 同步队列-无锁队列-循环数组无锁队列
java数组实现循环队列。包括入队, 出队,输出队列。 队列先入先出。