C++队列之动态分配数组

2024-05-09 18:32
文章标签 c++ 数组 队列 动态分配

本文主要是介绍C++队列之动态分配数组,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1 、队列之定义

 队列(Queue)是只允许在一端进行插入,而在另一端进行删除的运算受限的线性表

      

  (1)允许删除的一端称为队头(Front)。
  (2)允许插入的一端称为队尾(Rear)。
  (3)当队列中没有元素时称为空队列。
  (4)队列亦称作先进先出(First In First Out)的线性表,简称为FIFO表。
     队列的修改是依先进先出的原则进行的。新来的成员总是加入队尾(即不允许"加塞"),每次离开的成员总是队列头上的(不允许中途离队),即当前"最老的"成员离队。
 【例】在队列中依次加入元素a1,a2,…,an之后,a1是队头元素,an是队尾元素。退出队列的次序只能是a1,a2,…,an。

2、队列的基本逻辑运算
1)InitQueue(Q)
     置空队。构造一个空队列Q。

(2)QueueEmpty(Q)
     判队空。若队列Q为空,则返回真值,否则返回假值。

(3) QueueFull(Q)
     判队满。若队列Q为满,则返回真值,否则返回假值。
  注意:
     此操作只适用于队列的顺序存储结构。

(4) EnQueue(Q,x)
     若队列Q非满,则将元素x插入Q的队尾。此操作简称入队。

(5) DeQueue(Q)
     若队列Q非空,则删去Q的队头元素,并返回该元素。此操作简称出队。

(6) QueueFront(Q)
     若队列Q非空,则返回队头元素,但不改变队列Q的状态

那么下面来个示例来展现:

aqueue.h

#ifndef _AQUE_
#define _AQUE_#include <stdio.h>
#include <strings.h>
#include <stdlib.h>#define SIZE 10typedef int data_t;
typedef struct aqueue{data_t data[SIZE];int head;int tail;int num;
}AQUEUE;AQUEUE *creat_aqueue(void);
void init_aqueue(AQUEUE *Q);
int isfull_aqueue(AQUEUE *Q);
int isnull_aqueue(AQUEUE *Q);
void in_aqueue(AQUEUE *Q, data_t data);
data_t out_aqueue(AQUEUE *Q);#endif

aqueue.c

#include "aqueue.h"AQUEUE *creat_aqueue(void)
{AQUEUE *Q = (AQUEUE *)malloc(sizeof(AQUEUE));if(NULL == Q)exit(-1);bzero(Q, sizeof(AQUEUE));Q->head = 0;Q->tail = -1;Q->num = 0;return Q;
}void init_aqueue(AQUEUE *Q)
{bzero(Q, sizeof(AQUEUE));Q->head = 0;Q->tail = -1;Q->num = 0;
}int isfull_aqueue(AQUEUE *Q)
{return Q->num == SIZE?1:0;
}int isnull_aqueue(AQUEUE *Q)
{return Q->num == 0?1:0;
}void in_aqueue(AQUEUE *Q, data_t data)
{Q->tail = (Q->tail+1)%SIZE;Q->data[Q->tail] = data;Q->num++;
}data_t out_aqueue(AQUEUE *Q)
{data_t t = Q->data[Q->head];Q->head = (Q->head+1)%SIZE;Q->num--;return t;
}


main.c

#include "aqueue.h"int main()
{AQUEUE *Q = creat_aqueue();int i = 111;while(!isfull_aqueue(Q))in_aqueue(Q, i--);while(!isnull_aqueue(Q))printf("%d,", out_aqueue(Q));printf("\n");
}

 

缺点:从上面的代码中可以发现使用new 动态分配,对数组而言并不太合理,删除数组的一个元素,需要将余下的元素依次像前面移动,否则需要一些麻烦操作。

那么我们使用链表,是不是更加方便呢?

下一篇将使用C++的链表来解决这个问题!

 

期待将持续更新!

syw_selfimpr新浪微博地址: http://weibo.com/u/2945271402


注:以上代码在ubuntu下的gcc下编译正常运行!vs也可!

这篇关于C++队列之动态分配数组的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/974165

相关文章

C++快速排序超详细讲解

《C++快速排序超详细讲解》快速排序是一种高效的排序算法,通过分治法将数组划分为两部分,递归排序,直到整个数组有序,通过代码解析和示例,详细解释了快速排序的工作原理和实现过程,需要的朋友可以参考下... 目录一、快速排序原理二、快速排序标准代码三、代码解析四、使用while循环的快速排序1.代码代码1.由快

VSCode中C/C++编码乱码问题的两种解决方法

《VSCode中C/C++编码乱码问题的两种解决方法》在中国地区,Windows系统中的cmd和PowerShell默认编码是GBK,但VSCode默认使用UTF-8编码,这种编码不一致会导致在VSC... 目录问题方法一:通过 Code Runner 插件调整编码配置步骤方法二:在 PowerShell

C/C++随机数生成的五种方法

《C/C++随机数生成的五种方法》C++作为一种古老的编程语言,其随机数生成的方法已经经历了多次的变革,早期的C++版本使用的是rand()函数和RAND_MAX常量,这种方法虽然简单,但并不总是提供... 目录C/C++ 随机数生成方法1. 使用 rand() 和 srand()2. 使用 <random

Win32下C++实现快速获取硬盘分区信息

《Win32下C++实现快速获取硬盘分区信息》这篇文章主要为大家详细介绍了Win32下C++如何实现快速获取硬盘分区信息,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 实现代码CDiskDriveUtils.h#pragma once #include <wtypesbase

Java中数组转换为列表的两种实现方式(超简单)

《Java中数组转换为列表的两种实现方式(超简单)》本文介绍了在Java中将数组转换为列表的两种常见方法使用Arrays.asList和Java8的StreamAPI,Arrays.asList方法简... 目录1. 使用Java Collections框架(Arrays.asList)1.1 示例代码1.

C++ Primer 标准库vector示例详解

《C++Primer标准库vector示例详解》该文章主要介绍了C++标准库中的vector类型,包括其定义、初始化、成员函数以及常见操作,文章详细解释了如何使用vector来存储和操作对象集合,... 目录3.3标准库Vector定义和初始化vector对象通列表初始化vector对象创建指定数量的元素值

C++实现回文串判断的两种高效方法

《C++实现回文串判断的两种高效方法》文章介绍了两种判断回文串的方法:解法一通过创建新字符串来处理,解法二在原字符串上直接筛选判断,两种方法都使用了双指针法,文中通过代码示例讲解的非常详细,需要的朋友... 目录一、问题描述示例二、解法一:将字母数字连接到新的 string思路代码实现代码解释复杂度分析三、

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

C++一个数组赋值给另一个数组方式

《C++一个数组赋值给另一个数组方式》文章介绍了三种在C++中将一个数组赋值给另一个数组的方法:使用循环逐个元素赋值、使用标准库函数std::copy或std::memcpy以及使用标准库容器,每种方... 目录C++一个数组赋值给另一个数组循环遍历赋值使用标准库中的函数 std::copy 或 std::

C++使用栈实现括号匹配的代码详解

《C++使用栈实现括号匹配的代码详解》在编程中,括号匹配是一个常见问题,尤其是在处理数学表达式、编译器解析等任务时,栈是一种非常适合处理此类问题的数据结构,能够精确地管理括号的匹配问题,本文将通过C+... 目录引言问题描述代码讲解代码解析栈的状态表示测试总结引言在编程中,括号匹配是一个常见问题,尤其是在