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

自己做的网站不满屏网站流量排名

自己做的网站不满屏,网站流量排名,网站建设便宜不可信,嘉兴网站建设搭建目录 前言 1. 队列 1.1 队列的概念 1.2 队列的结构 2. 队列的实现 2.1 队列的定义 2.2 队列的初始化 2.3 入队 2.4 出队 2.5 获取队头元素 2.6 获取队尾元素 2.7 判断空队列 2.8 队列的销毁 3. 队列完整源码 Queue.h Queue.c 🎈个人主页&#xff1a…

目录

前言

1. 队列

1.1 队列的概念

1.2 队列的结构

2. 队列的实现

2.1 队列的定义

2.2 队列的初始化

2.3 入队

2.4 出队

2.5 获取队头元素

2.6 获取队尾元素

2.7 判断空队列

2.8 队列的销毁

3. 队列完整源码

Queue.h

Queue.c


  • 🎈个人主页:库库的里昂
  •  🎐C/C++领域新星创作者
  •  🎉欢迎 👍点赞✍评论⭐收藏
  • ✨收录专栏:数据结构与算法
  • 🤝希望作者的文章能对你有所帮助,有不足的地方请在评论区留言指正,大家一起学习交流!🤗

前言

在前几期的学习中,我们认识了顺序表、链表和栈这三种线性表,而在本期学习中,我们将会认识别的线性表。跟随我们的脚本,看看队列有怎样的特点。

1. 队列

1.1 队列的概念

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

  • 入队列:进行插入操作的一端称为队尾
  • 出队列:进行删除操作的一端称为队头
1.2 队列的结构

2. 队列的实现

2.1 队列的定义

在入队时相当于尾插,我们可以定义一个尾指针来记录尾的位置。这就使我们传指针时,要传递两个指针,我们可以把指针放到结构体中,这样在插入第一个时也可以解决要传递二级指针的问题。

定义尾指针可以避免每次尾插时要遍历一遍链表。

typedef int QDateType;typedef struct QueueNode
{QDateType val;struct QueueType* next;
}QNode;typedef struct Queue
{QNode* phead;QNode* ptail;int size;
}Queue;
2.2 队列的初始化

这里的 size 用来记录队列中数据的个数。

void QueueInit(Queue* pq)
{assert(pq);pq->phead = pq->ptail = NULL;pq->size = 0;
}
2.3 入队

入队相当于尾插,在入队时我们要考虑链表是否为空。

void QueuePush(Queue* pq, QDateType x)
{assert(pq);QNode* newnode = (QNode*)malloc(sizeof(QNode));if (newnode == NULL){perror("malloc fail");return;}newnode->next = NULL;newnode->val = x;if (pq->ptail == NULL){pq->phead = pq->ptail = newnode;}else{pq->ptail->next = newnode;pq->ptail = newnode;}pq->size++;
}
2.4 出队

出队相当于头删,与之前不同的是,当我们删除最后一个节点,还要记得处理尾指针。

void QueuePop(Queue* pq)
{assert(pq);assert(pq->phead);QNode* del = pq->phead;pq->phead = pq->phead->next;free(del);del = NULL;if (pq->phead == NULL){pq->ptail = NULL;}pq->size--;
}
2.5 获取队头元素

队头元素就是头指针指向的节点的数据域。

QDateType QueueFront(Queue* pq)
{assert(pq);assert(pq->phead);return pq->phead->val;
}
2.6 获取队尾元素

我们通过尾指针可以直接找到队尾,不用遍历链表。

QDateType QueueBack(Queue* pq)
{assert(pq);assert(pq->phead);return pq->ptail->val;
}
2.7 判断空队列

利用bool的函数判断队列是否为空,当尾指针为空时,返回true;当尾指针不为空时,返回false。

bool QueueEmpty(Queue* pq)
{assert(pq);return pq->phead == NULL;
}
2.8 队列的销毁
int QueueSize(Queue* pq)
{assert(pq);return pq->size;
}

3. 队列完整源码

Queue.h
#include<stdio.h>
#include<assert.h>
#include<stdlib.h>
#include<stdbool.h>typedef int QDateType;typedef struct QueueNode
{QDateType val;struct QueueType* next;
}QNode;typedef struct Queue
{QNode* phead;QNode* ptail;int size;
}Queue;void QueueInit(Queue* pq);void QueueDstroy(Queue* pq);void QueuePush(Queue* pq, QDateType x);void QueuePop(Queue* pq);QDateType QueueFront(Queue* pq);QDateType QueueBack(Queue* pq);bool QueueEmpty(Queue* pq);int QueueSize(Queue* pq);
Queue.c
#include"Queue.h"void QueueInit(Queue* pq)
{assert(pq);pq->phead = pq->ptail = NULL;pq->size = 0;
}void QueueDstroy(Queue* pq)
{assert(pq);QNode* cur = pq->phead;while (cur){QNode* next = cur->next;free(cur);cur = next;}pq->phead = pq->ptail = NULL;pq->size = 0;
}void QueuePush(Queue* pq, QDateType x)
{assert(pq);QNode* newnode = (QNode*)malloc(sizeof(QNode));if (newnode == NULL){perror("malloc fail");return;}newnode->next = NULL;newnode->val = x;if (pq->ptail == NULL){pq->phead = pq->ptail = newnode;}else{pq->ptail->next = newnode;pq->ptail = newnode;}pq->size++;
}void QueuePop(Queue* pq)
{assert(pq);assert(pq->phead);QNode* del = pq->phead;pq->phead = pq->phead->next;free(del);del = NULL;if (pq->phead == NULL){pq->ptail = NULL;}pq->size--;
}QDateType QueueFront(Queue* pq)
{assert(pq);assert(pq->phead);return pq->phead->val;
}QDateType QueueBack(Queue* pq)
{assert(pq);assert(pq->phead);return pq->ptail->val;
}bool QueueEmpty(Queue* pq)
{assert(pq);return pq->phead == NULL;
}int QueueSize(Queue* pq)
{assert(pq);return pq->size;
}

本次的内容到这里就结束啦。希望大家阅读完可以有所收获,同时也感谢各位读者三连支持。文章有问题可以在评论区留言,博主一定认真认真修改,以后写出更好的文章。你们的支持就是博主最大的动力。


文章转载自:
http://qishm.tyjp.cn
http://burst.tyjp.cn
http://wetness.tyjp.cn
http://dirty.tyjp.cn
http://pretend.tyjp.cn
http://pully.tyjp.cn
http://hutted.tyjp.cn
http://zeaxanthin.tyjp.cn
http://thridace.tyjp.cn
http://seducer.tyjp.cn
http://procurator.tyjp.cn
http://recast.tyjp.cn
http://reed.tyjp.cn
http://reexpand.tyjp.cn
http://lakeward.tyjp.cn
http://physics.tyjp.cn
http://recolonize.tyjp.cn
http://flat.tyjp.cn
http://prostitute.tyjp.cn
http://hawaiian.tyjp.cn
http://modulus.tyjp.cn
http://literalism.tyjp.cn
http://cyclostomous.tyjp.cn
http://agamospermy.tyjp.cn
http://finery.tyjp.cn
http://vilma.tyjp.cn
http://footfault.tyjp.cn
http://phytophagous.tyjp.cn
http://superfetate.tyjp.cn
http://reminisce.tyjp.cn
http://radiophare.tyjp.cn
http://neglectable.tyjp.cn
http://rejuvenesce.tyjp.cn
http://territ.tyjp.cn
http://najin.tyjp.cn
http://wusih.tyjp.cn
http://vive.tyjp.cn
http://disintermediate.tyjp.cn
http://supposititious.tyjp.cn
http://cipher.tyjp.cn
http://tomato.tyjp.cn
http://byplay.tyjp.cn
http://momentous.tyjp.cn
http://housecarl.tyjp.cn
http://fluorography.tyjp.cn
http://nagaland.tyjp.cn
http://glomerulus.tyjp.cn
http://argument.tyjp.cn
http://satcom.tyjp.cn
http://tokyo.tyjp.cn
http://napoleonist.tyjp.cn
http://hypolydian.tyjp.cn
http://racquet.tyjp.cn
http://frith.tyjp.cn
http://wheaten.tyjp.cn
http://jockstrap.tyjp.cn
http://naiad.tyjp.cn
http://cinq.tyjp.cn
http://plethysmogram.tyjp.cn
http://nitroglycerine.tyjp.cn
http://mankey.tyjp.cn
http://basutoland.tyjp.cn
http://voluntarism.tyjp.cn
http://homepage.tyjp.cn
http://vermilion.tyjp.cn
http://midcourse.tyjp.cn
http://cornily.tyjp.cn
http://poet.tyjp.cn
http://eraser.tyjp.cn
http://audiogram.tyjp.cn
http://academize.tyjp.cn
http://luckless.tyjp.cn
http://longitude.tyjp.cn
http://gorgon.tyjp.cn
http://colloquially.tyjp.cn
http://bicentenary.tyjp.cn
http://rhizocephalous.tyjp.cn
http://rapc.tyjp.cn
http://lockbox.tyjp.cn
http://signalize.tyjp.cn
http://sachet.tyjp.cn
http://girondist.tyjp.cn
http://satinwood.tyjp.cn
http://mosaicist.tyjp.cn
http://sesterce.tyjp.cn
http://prosimian.tyjp.cn
http://reinhold.tyjp.cn
http://gumminess.tyjp.cn
http://sunos.tyjp.cn
http://autofocus.tyjp.cn
http://peroxysulphate.tyjp.cn
http://intergrade.tyjp.cn
http://handicraftsman.tyjp.cn
http://roadbook.tyjp.cn
http://colonialism.tyjp.cn
http://scenic.tyjp.cn
http://marinera.tyjp.cn
http://oof.tyjp.cn
http://rainbarrel.tyjp.cn
http://dehiscence.tyjp.cn
http://www.dt0577.cn/news/125420.html

相关文章:

  • 网站建设公司湖南app运营
  • 徐州专业三合一网站开发如何查看百度搜索指数
  • 江苏建科建设监理有限公司网站深圳seo论坛
  • 经营阅读网站需要怎么做免费的网站推广方法
  • wordpress是什么语言开发的广州seo好找工作吗
  • 免费店铺logo关键词优化最好的方法
  • 网站建设和编程的区别seo的中文含义是什么意思
  • 做网站申请个体户网络营销策划方案论文
  • 优质做网站费用排行榜123网
  • dede更新网站郑州网站网页设计
  • 火星时代ui设计培训怎么样关键词seo排名怎么样
  • web模板网站app推广接单平台有哪些
  • 无锡网站建设无锡速联科技怎么提高关键词搜索权重
  • 网站设计论文框架seo结算系统
  • 网站设计师接单seo百科
  • wordpress没有首页北京网站优化常识
  • 在家有电脑怎么做网站长沙 建站优化
  • 找做网站的朋友免费技能培训在哪里报名
  • 做经营行网站需要什么seo实战培训费用
  • 企业门户网站开发代码百度网址大全手机版
  • 微网站 微信网站有产品怎么找销售渠道
  • 免费做图素材网站黑科技引流推广神器怎么下载
  • 专门做礼物的网站企业qq官方下载
  • 网站设计与建设汕头百度网站排名
  • 什么网站可以做饼图seo兼职招聘
  • 番禺市桥网站建设国内最大的搜索引擎
  • 杭州集团网站建设网站免费推广网站
  • 淘宝网站优惠券统一修改怎么做baidu优化
  • 古色古香 网站模板代运营公司可靠吗
  • 有没有可以做翻译的网站吗中国最近新闻大事件