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++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

MySQL JSON 查询中的对象与数组技巧及查询示例

《MySQLJSON查询中的对象与数组技巧及查询示例》MySQL中JSON对象和JSON数组查询的详细介绍及带有WHERE条件的查询示例,本文给大家介绍的非常详细,mysqljson查询示例相关知... 目录jsON 对象查询1. JSON_CONTAINS2. JSON_EXTRACT3. JSON_TA

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

Java中常见队列举例详解(非线程安全)

《Java中常见队列举例详解(非线程安全)》队列用于模拟队列这种数据结构,队列通常是指先进先出的容器,:本文主要介绍Java中常见队列(非线程安全)的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一.队列定义 二.常见接口 三.常见实现类3.1 ArrayDeque3.1.1 实现原理3.1.2

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

C++/类与对象/默认成员函数@构造函数的用法

《C++/类与对象/默认成员函数@构造函数的用法》:本文主要介绍C++/类与对象/默认成员函数@构造函数的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录名词概念默认成员函数构造函数概念函数特征显示构造函数隐式构造函数总结名词概念默认构造函数:不用传参就可以

C++类和对象之默认成员函数的使用解读

《C++类和对象之默认成员函数的使用解读》:本文主要介绍C++类和对象之默认成员函数的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、默认成员函数有哪些二、各默认成员函数详解默认构造函数析构函数拷贝构造函数拷贝赋值运算符三、默认成员函数的注意事项总结一