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

专门做黄漫的网站宁波网络推广方式

专门做黄漫的网站,宁波网络推广方式,深圳酒店vi设计公司,防护网施工方案数据结构——队列 一、队列的概念二、队列的实现方式三、队列所需要的接口四、接口的详细实现4.1初始化4.2销毁4.3入队4.5出队4.6获取队头元素4.7获取队尾元素4.8获取队列元素个数4.9判空 五、完整代码5.1Queue.h5.2Queue.c5.3test.c 一、队列的概念 队列:只允许在…

数据结构——队列

  • 一、队列的概念
  • 二、队列的实现方式
  • 三、队列所需要的接口
  • 四、接口的详细实现
    • 4.1初始化
    • 4.2销毁
    • 4.3入队
    • 4.5出队
    • 4.6获取队头元素
    • 4.7获取队尾元素
    • 4.8获取队列元素个数
    • 4.9判空
  • 五、完整代码
    • 5.1Queue.h
    • 5.2Queue.c
    • 5.3test.c

一、队列的概念

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

在这里插入图片描述

二、队列的实现方式

队列可以用数组和链表的结构实现,使用链表的结构实现更优一些,因为如果使用数组的结构,出队列在数组头上出数据,效率会比较低。

三、队列所需要的接口

//初始化
void QueueInit(Queue* pq);//销毁
void QueueDestory(Queue* pq);//入队
void QueuePush(Queue* pq, Queuedatatype x);//出队
void QueuePop(Queue* pq);//获取队头元素
Queuedatatype QueueFront(Queue* pq);//获取队尾元素
Queuedatatype QueueBack(Queue* pq);//获取队列元素个数
int Queuesize(Queue* pq);//判空
bool QueueEmpty(Queue* pq);

四、接口的详细实现

4.1初始化

初始化:我们需要将pq->phead和pq->ptail都置为NULL,并且将pq->size置为0;

oid QueueInit(Queue* pq)
{assert(pq);pq->phead = NULL;pq->ptail = NULL;pq->size = 0;
}

4.2销毁

销毁:首先定义一个cur指针保存头节点phead的地址,接下来利用cur!=NULL使得循环往下走,在循环内定义一个next的指针来更新地址,并且用free来释放内存,出循环后,将pq->phead,pq->ptail都置为NULL,并且将pq->size置为0。

void QueueDestory(Queue* pq)
{assert(pq);Queuenode* cur = pq->phead;while (cur){Queue* next = cur->next;free(cur);cur = next;}pq->phead = pq->ptail = NULL;pq->size = 0;
}

在这里插入图片描述

4.3入队

入队:入队有两种情况。第一种,队内无其他元素;第二种,队内有其他元素。
①、队内无其他元素:直接让pq->phead = pq->ptail = newnode;
在这里插入图片描述
②、队内有其它元素:如果队列不为NULL,我们需要让pq->ptail->next指向newnode,并且最后再让pq->ptail指向newnode.
在这里插入图片描述

oid QueuePush(Queue* pq, Queuedatatype x)
{assert(pq);Queuenode* newnode = (Queuenode*)malloc(sizeof(Queuenode));if (newnode == NULL){perror("malloc fail");return;}newnode->data = x;newnode->next = NULL;//队内无其它元素if (pq->phead == NULL){assert(pq->ptail == NULL);pq->phead = pq->ptail = newnode;}else{//链接pq->ptail->next = newnode;pq->ptail = newnode;}pq->size++;
}

4.5出队

出队:出队列大体上分为两种情况:有节点和无节点。
①、如果队列中没有节点,就不能进行出队操作,我们这时可以用assert(!QueueEmpty(pq)); 来进行判断。
②、队列中有节点时,又可以分为一个节点和多个节点之分,如果队列中只有一个节点时,我们直接用free 置空;如果队列中有多个节点时,首先、创建一个next用来保存phead的下一个节点的地址,我们free(phead),再让phead等于我们的next。

// 出队
void QueuePop(Queue * pq)
{assert(pq);assert(!QueueEmpty(pq));//一个节点if (pq->phead->next == NULL){free(pq->phead);pq->phead = pq->ptail=NULL;}//多个节点else{//头删Queuenode* next = pq->phead->next;free(pq->phead);pq->phead = next;}pq->size--;
}

4.6获取队头元素

//获取队头元素
Queuedatatype QueueFront(Queue* pq)
{assert(pq);return pq->phead->data;
}

4.7获取队尾元素

//获取队尾元素
Queuedatatype QueueBack(Queue* pq)
{assert(pq);return pq->ptail->data;
}

4.8获取队列元素个数

//获取队列元素个数
int Queuesize(Queue* pq)
{assert(pq);return pq->size;
}

4.9判空

如果pq->size==0时,便证明队列为NULL。

//判空
bool QueueEmpty(Queue* pq)
{assert(pq);return pq->size == 0;
}

五、完整代码

5.1Queue.h

#pragma once
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include<stdbool.h>typedef int Queuedatatype;
//定义队列结构
typedef struct Queuenode
{struct Queuenode* next;Queuedatatype data;
}Queuenode;typedef struct Queue
{Queuenode* phead;Queuenode* ptail;int size;
}Queue;//初始化
void QueueInit(Queue* pq);//销毁
void QueueDestory(Queue* pq);//入队
void QueuePush(Queue* pq, Queuedatatype x);//出队
void QueuePop(Queue* pq);//获取队头元素
Queuedatatype QueueFront(Queue* pq);//获取队尾元素
Queuedatatype QueueBack(Queue* pq);//获取队列元素个数
int Queuesize(Queue* pq);//判空
bool QueueEmpty(Queue* pq);

5.2Queue.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"Queue.h"
//初始化
void QueueInit(Queue* pq)
{assert(pq);pq->phead = NULL;pq->ptail = NULL;pq->size = 0;
}//销毁
void QueueDestory(Queue* pq)
{assert(pq);Queuenode* cur = pq->phead;while (cur){Queue* next = cur->next;free(cur);cur = next;}pq->phead = pq->ptail = NULL;pq->size = 0;
}//入队
void QueuePush(Queue* pq, Queuedatatype x)
{assert(pq);Queuenode* newnode = (Queuenode*)malloc(sizeof(Queuenode));if (newnode == NULL){perror("malloc fail");return;}newnode->data = x;newnode->next = NULL;if (pq->phead == NULL){assert(pq->ptail == NULL);pq->phead = pq->ptail = newnode;}//链接pq->ptail->next = newnode;pq->ptail = newnode;pq->size++;
}// 出队
void QueuePop(Queue * pq)
{assert(pq);assert(!QueueEmpty(pq));//一个节点if (pq->phead->next == NULL){free(pq->phead);pq->phead = pq->ptail=NULL;}//多个节点else{//头删Queuenode* next = pq->phead->next;free(pq->phead);pq->phead = next;}pq->size--;
}//获取队头元素
Queuedatatype QueueFront(Queue* pq)
{assert(pq);return pq->phead->data;
}//获取队尾元素
Queuedatatype QueueBack(Queue* pq)
{assert(pq);return pq->ptail->data;
}//获取队列元素个数
int Queuesize(Queue* pq)
{assert(pq);return pq->size;
}//判空
bool QueueEmpty(Queue* pq)
{assert(pq);return pq->size == 0;
}

5.3test.c

#define _CRT_SECURE_NO_WARNINGS 1
#include"Queue.h"
void test1()
{Queue q;QueueInit(&q);QueuePush(&q, 1);QueuePush(&q, 2);QueuePush(&q, 3);QueuePush(&q, 4);printf("Size:%d\n", Queuesize(&q));while (!QueueEmpty(&q)){printf("%d ", QueueFront(&q));QueuePop(&q);}}
int main()
{test1();return 0;
}
http://www.khdw.cn/news/17646.html

相关文章:

  • wordpress后台导入数据库百度上做优化
  • 做的网站用户密码在哪里找建立一个国外的网站
  • 什么样的网站需要改版网络营销主要学什么
  • 网站的回到顶部怎么做广州网站制作服务
  • 邯郸做网站哪里好抖音运营推广策划方案
  • 网站建设合同的要素全国疫情实时动态
  • 南通优化网站收费标准国际形势最新消息
  • 做网站外包工作怎么样谷歌搜索引擎营销
  • 网站模板 免费小程序开发平台官网
  • 网站建设进度b站怎么推广
  • dedecms手机版天津优化加盟
  • 冷库网站建设企业网站优化外包
  • index 石家庄网站建设优化营商环境心得体会个人
  • 如何做代购网站设计事件营销的概念
  • 长沙网站制作公司有哪些市场营销主要学什么
  • 杭州展示型网站建设重庆百度推广
  • 网站怎么发布到服务器百度下载安装2019
  • 网站开发 会费管理 模块免费刷赞网站推广qq免费
  • 个人怎么开网上超市seo快速排名站外流量推广
  • 进行网站开发 如何搭建环境爱站关键词
  • 网站开发项目规划谷歌站长平台
  • 石狮网站建设报价文案发布平台
  • 外贸建站哪家公司好自媒体平台注册官网下载
  • 网站建设设计制作培训百度营销登录平台
  • 2345浏览器免费版seo搜索排名
  • 网络营销分析论文福州seo博客
  • 营销推广方案怎么写临沧seo
  • 传奇私服网站做ssl春哥seo博客
  • 企业网站做多大尺寸seo内部优化包括哪些内容
  • php做的购物网站系统下载百度获客平台怎么收费的