当前位置: 首页 > news >正文

网站优化公司上海今科云平台网站建设技术开发

网站优化公司上海,今科云平台网站建设技术开发,苏州网站开发公司兴田德润怎么联系,网站建设 绵阳队列 队列的概念及结构 队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出 FIFO(First In First Out) 入队列:进行插入操作的一端称为队尾 出队列:进行删除操作的一端称为队…

在这里插入图片描述

队列

队列的概念及结构

队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出
FIFO(First In First Out) 入队列:进行插入操作的一端称为队尾 出队列:进行删除操作的一端称为队头
在这里插入图片描述

队列的实现

队列也可以数组和链表的结构实现,使用链表的结构实现更优一些,因为如果使用数组的结构,出队列在数
组头上出数据,效率会比较低
在这里插入图片描述

// 链式结构:表示队列
typedef struct QListNode
{ struct QListNode* _pNext; QDataType _data; 
}QNode; 
// 队列的结构
typedef struct Queue
{ QNode* _front; QNode* _rear; 
}Queue; 
// 初始化队列
void QueueInit(Queue* q); 
// 队尾入队列
void QueuePush(Queue* q, QDataType data); 
// 队头出队列
void QueuePop(Queue* q); 
// 获取队列头部元素
QDataType QueueFront(Queue* q); 
// 获取队列队尾元素
QDataType QueueBack(Queue* q); 
// 获取队列中有效元素个数
int QueueSize(Queue* q); 
// 检测队列是否为空,如果为空返回非零结果,如果非空返回0 
int QueueEmpty(Queue* q); 
// 销毁队列
void QueueDestroy(Queue* q);

总的代码如下

#include "Queue.h"void QueueInit(Que* pq)
{assert(pq);pq->head = pq->tail = NULL;pq->size = 0;
}void QueueDestroy(Que* pq)
{assert(pq);QNode* cur = pq->head;while (cur){QNode* next = cur->next;free(cur);cur = next;}pq->head = pq->tail = NULL;pq->size = 0;
}void QueuePush(Que* pq, QDataType x)
{assert(pq);QNode* newnode = (QNode*)malloc(sizeof(QNode));if (newnode == NULL){perror("malloc fail");exit(-1);}newnode->data = x;newnode->next = NULL;if (pq->tail == NULL){pq->head = pq->tail = newnode;}else{pq->tail->next = newnode;pq->tail = newnode;}pq->size++;
}void QueuePop(Que* pq)
{assert(pq);assert(!QueueEmpty(pq));if (pq->head->next == NULL){free(pq->head);pq->head = pq->tail = NULL;}else{QNode* next = pq->head->next;free(pq->head);pq->head = next;}pq->size--;
}QDataType QueueFront(Que* pq)
{assert(pq);assert(!QueueEmpty(pq));return pq->head->data;
}QDataType QueueBack(Que* pq)
{assert(pq);assert(!QueueEmpty(pq));return pq->tail->data;
}bool QueueEmpty(Que* pq)
{assert(pq);return pq->head == NULL;
}int QueueSize(Que* pq)
{assert(pq);return pq->size;
}
#pragma once#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<stdbool.h>typedef int QDataType;
typedef struct QueueNode
{struct QueueNode* next;QDataType data;
}QNode;typedef struct Queue
{QNode* head;QNode* tail;int size;
}Que;void QueueInit(Que* pq);
void QueueDestroy(Que* pq);
void QueuePush(Que* pq, QDataType x);
void QueuePop(Que* pq);
QDataType QueueFront(Que* pq);
QDataType QueueBack(Que* pq);
bool QueueEmpty(Que* pq);
int QueueSize(Que* pq);
http://www.yayakq.cn/news/963133/

相关文章:

  • 企业网站后台管理软件建设博物馆网站
  • 网站公司如何推广网站做网站先买域名
  • 网站如何做谷歌推广长沙模板建网站需要多久
  • 销售网站怎么做的wordpress大流量
  • 什么是建设企业网站网站在线咨询怎么做
  • 域名怎么绑定自己网站前端素材网
  • 政务系统网站建设工作先进个人主要事迹在电脑上哪里可以做网站
  • 网站开发公司经营范围小公司怎样自己建网站
  • 网站开发需要研究什么网站建设必须买数据库么
  • 城乡住房建设厅网站中国老区建设促进会网站
  • 京东网站建设策略免费建立属于自己的网站
  • 个人电脑搭建成网站服务器企业网站营销的实现方式解读
  • 用idea做html网站龙华网站建设推广
  • 网站手机端和电脑端安卓应用开发工具
  • 手机端做网站软件甘肃省住房和城乡建设部网站
  • 福建有没有网站做鞋子一件代发毕设做网站太简单
  • 网站建设课程设计心得体会重庆做网站哪家好
  • 四川绵阳网站建设网站带gov后缀
  • 找人做公司网站asp做网站策划书
  • 东莞cms建站模板衡阳市城市建设投资有限公司网站
  • 最全的网页模板网站物流跟踪网站建设
  • 专门网站建设北京百度推广优化公司
  • 怎么选择一家好的网站建设公司网上注册公司经营范围填不了
  • 织梦网站动态wordpress显示目录
  • 一站式 wordpress微网站建设代理商
  • 专业网站设计报价企业网站建设综合实训学习体会
  • 东莞模板建网站平台广州代做公司网站
  • 网站开发网站建设公司上海开发小程序
  • 网站插件代码大全酒店网站源码
  • 如何管理建好的网站蘑菇街网站服务