我们知道,在数组中,若知道数据项的下标,便可立即访问该数据项,或者通过顺序搜索数据项,访问到数组中的各个数据项。但是栈和队列不同,它们的访问是受限制的,即在特定时刻只有一个数据项可以被读取或者被删除。众所周知,栈是先进后出,只能访问栈顶的数据,队列是先进先出,只能访问头部数据。这里不再赘述。
栈的主要机制可以用数组来实现,也可以用链表来实现,下面用数组来实现栈的基本操作:
- public class ArrayStack {
- private long[] a;
- private int size; //栈数组的大小
- private int top; //栈顶
- public ArrayStack(int maxSize) {
- this.size = maxSize;
- this.a = new long[size];
- this.top = -1; //表示空栈
- }
- public void push(long value) {//入栈
- if(isFull()) {
- System.out.println("栈已满!");
- return;
- }
- a[++top] = value;
- }
- public long peek() {//返回栈顶内容,但不删除
- if(isEmpty()) {
- System.out.println("栈中没有数据");
- return 0;
- }
- return a[top];
- }
- public long pop() { //弹出栈顶内容,删除
- if(isEmpty()) {
- System.out.println("栈中没有数据!");
- return 0;
- }
- return a[top--];
- }
- public int size() {
- return top + 1;
- }
- public boolean isEmpty() {
- return (top == -1);
- }
- public boolean isFull() {
- return (top == size -1);
- }
- public void display() {
- for(int i = top; i >= 0; i--) {
- System.out.print(a[i] + " ");
- }
- System.out.println("");
- }
- }
数据项入栈和出栈的时间复杂度均为O(1)。这也就是说,栈操作所消耗的时间不依赖于栈中数据项的个数,因此操作时间很短。栈不需要比较和移动操作。
队列也可以用数组来实现,不过这里有个问题,当数组下标满了后就不能再添加了,但是数组前面由于已经删除队列头的数据了,导致空。所以队列我们可以用循环数组来实现,见下面的代码:
- public class RoundQueue {
- private long[] a;
- private int size; //数组大小
- private int nItems; //实际存储数量
- private int front; //头
- private int rear; //尾
- public RoundQueue(int maxSize) {
- this.size = maxSize;
- a = new long[size];
- front = 0;
- rear = -1;
- nItems = 0;
- }
- public void insert(long value) {
- if(isFull()){
- System.out.println("队列已满");
- return;
- }
- rear = ++rear % size;
- a[rear] = value; //尾指针满了就循环到0处,这句相当于下面注释内容
- nItems++;
- /* if(rear == size-1){
- rear = -1;
- }
- a[++rear] = value;
- */
- }
- public long remove() {
- if(isEmpty()) {
- System.out.println("队列为空!");
- return 0;
- }
- nItems--;
- front = front % size;
- return a[front++];
- }
- public void display() {
- if(isEmpty()) {
- System.out.println("队列为空!");
- return;
- }
- int item = front;
- for(int i = 0; i < nItems; i++) {
- System.out.print(a[item++ % size] + " ");
- }
- System.out.println("");
- }
- public long peek() {
- if(isEmpty()) {
- System.out.println("队列为空!");
- return 0;
- }
- return a[front];
- }
- public boolean isFull() {
- return (nItems == size);
- }
- public boolean isEmpty() {
- return (nItems == 0);
- }
- public int size() {
- return nItems;
- }
- }
和栈一样,队列中插入数据项和删除数据项的时间复杂度均为O(1)。
还有个优先级队列,优先级队列是比栈和队列更专用的数据结构。优先级队列与上面普通的队列相比,主要区别在于队列中的元素是有序的,关键字最小(或者最大)的数据项总在队头。数据项插入的时候会按照顺序插入到合适的位置以确保队列的顺序。优先级队列的内部实现可以用数组或者一种特别的树——堆来实现。堆可参考第8节内容。这里用数组实现优先级队列。
- public class PriorityQueue {
- private long[] a;
- private int size;
- private int nItems;//元素个数
- public PriorityQueue(int maxSize) {
- size = maxSize;
- nItems = 0;
- a = new long[size];
- }
- public void insert(long value) {
- if(isFull()){
- System.out.println("队列已满!");
- return;
- }
- int j;
- if(nItems == 0) { //空队列直接添加
- a[nItems++] = value;
- }
- else{//将数组中的数字依照下标按照从大到小排列
- for(j = nItems-1; j >= 0; j--) {
- if(value > a[j]){
- a[j+1] = a[j];
- }
- else {
- break;
- }
- }
- a[j+1] = value;
- nItems++;
- }
- }
- public long remove() {
- if(isEmpty()){
- System.out.println("队列为空!");
- return 0;
- }
- return a[--nItems];
- }
- public long peekMin() {
- return a[nItems-1];
- }
- public boolean isFull() {
- return (nItems == size);
- }
- public boolean isEmpty() {
- return (nItems == 0);
- }
- public int size() {
- return nItems;
- }
- public void display() {
- for(int i = nItems-1; i >= 0; i--) {
- System.out.print(a[i] + " ");
- }
- System.out.println(" ");
- }
- }
这里实现的优先级队列中,插入操作需要O(N)的时间,而删除操作则需要O(1)的时间。在第8节里将介绍堆来改进插入操作的时间。
相关推荐
本资源为数据结构与算法第四章(栈和队列)的作业程序代码。包含以下的两个程序: 4.3火车硬软座问题 4.11rear和length表示的循环队列入出队 北工大电控学院《数据结构与算法》课程的其它章节程序实验及作业代码亦已...
JS 数据结构与算法.pdf 本书主要介绍了 JavaScript 语言的基础知识,包括数据结构和算法。以下是该书的详细知识点: 一、JavaScript 基础知识 * 变量和数据类型 * 运算符和控制结构 * 函数和对象 * 数组和字符串 ...
### 数据结构与算法:栈与队列题库解析 #### 一、判断题解析 1. **正确**。栈的特点就是后进先出(LIFO, Last In First Out),因此所有的插入与删除操作均发生在栈顶。 2. **正确**。队列是一种先进先出(FIFO, ...
数据结构与算法是计算机科学的基础,它涉及到如何有效地组织和管理数据,以便进行高效地查找、存储和处理。本资源包含的数据结构与算法课后习题答案,是学习这一领域的重要辅助材料,可以帮助学生深入理解和巩固所学...
数据结构与算法是计算机科学的基础,对于理解和设计高效的程序至关重要。在编程中,栈和队列是最基础也是最常用的两种数据结构。它们在各种场景下都有广泛应用,如内存管理、函数调用、网页浏览历史、任务调度等。在...
数据结构与算法是计算机科学的基础,对于理解和设计高效的软件至关重要。C语言因其高效、底层特性,常被用于实现数据结构和算法,使得程序更接近硬件,性能更优。本资源"数据结构与算法分析--C语言描述"是针对数据...
数据结构与算法 中国矿业大学出版社 主编 张小燕 第三章 栈和队列
数据结构与算法 数据结构与C语言 data structure课程 第3章 栈和队列(共150页).ppt 数据结构与算法 数据结构与C语言 data structure课程 第4章 串、数组和广义表(共66页).ppt 数据结构与算法 数据结构与C语言 ...
栈和队列是两种基础且重要的数据结构,广泛应用于各种算法和程序设计中。本课件及课堂笔记将深入探讨这两种数据结构的概念、特性以及它们在实际问题中的应用。 栈(Stack)是一种后进先出(LIFO,Last In First Out...
本次实验是关于数据结构中的队列基本操作算法。队列是一种先进先出(FIFO)的数据结构,在计算机科学中有着广泛的应用,例如进程调度、任务队列等场景。通过本实验,学生能够深入理解循环队列的概念,并熟练掌握其...
数据结构与算法分析是计算机科学中的核心课程,它关乎如何高效地存储和处理数据,以及设计和实现高效的计算过程。C++作为一种强大的编程语言,常用于实现这些数据结构和算法,因为它提供了丰富的库支持和面向对象的...
根据提供的文件信息,这里主要关注的是“C++数据结构与算法(第4版)”这一主题,虽然实际内容并未给出具体章节或知识点,但我们可以基于标题、描述以及部分已知内容来推测书中可能涵盖的关键知识点。 ### C++数据...
在IT领域,数据结构与算法是编程基础的重要组成部分,它们直接影响到程序的效率和优化能力。本资源"数据结构与算法代码详解JAVA版"聚焦于使用Java语言来理解和实现这些核心概念。 首先,数据结构是组织和存储数据的...
数据结构与算法(C#).PDF及代码 第1章 Collections类、泛型类和Timing类概述 第2章 数组和ArrayList 第3章 基础排序算法 第4章 基础查找算法 第5章 栈和队列 第6章 BitArray类 第7章 字符串、String类和StringBuioder...
数据结构与算法是计算机科学的基础,对于理解和设计高效的软件至关重要。本课程的资源"恋上数据结构与算法课件.rar"涵盖了多个核心概念,旨在...爱数据结构与算法,就立即行动,打开这个压缩包,开始你的学习之旅吧!
数据结构与算法是计算机科学中的核心课程,它探讨如何有效地组织和处理数据,以及如何设计和分析解决问题的算法。这份“数据结构与算法-PPT课件”提供了丰富的学习材料,涵盖了多个关键主题。 首先,我们要了解数据...