数据结构 第三章 栈和队列(队列)
创始人
2024-05-18 20:14:33

感谢:点击收听

1 基本知识点

1、允许删除的一端称为队头(front)
2、允许插入的一端称为队尾(rear)
3、当队列中没有元素时称为空队列
4、顺序队列:

1 使用顺序表来实现队列
2 两个指针分别指向队列的前端和尾端
**3 如果队列的大小为MaxSize个,那么元素的下标范围从0到MaxSize-1**
4 假设队头指针front指向队头元素的前一个位置,队尾指针rear指向队尾元素

顺序队列存在“假上溢”现象:
由于入队和出队操作中,头尾指针只增加不减小,致使被删元素的空间永远无法重新利用。
当队列中实际的元素个数远远小于向量空间的规模时,也可能由于尾指针已超越向量空间的上界而不能做入队操作。

5、循环队列
请添加图片描述

1 满队列条件:Q.rear = Q.front;
2 空队列条件:Q.rear = Q.front;
如何区分? 

区分队列是满还是空:

1 牺牲一个存储空间(front与rear是相邻的而非相等的)
2 引入一个标志变量flag区别空和不空
3 使用计数器count

请添加图片描述
请添加图片描述
如果选择牺牲一个空间的方法,那么满队列的判断条件为:

(rear+1)%MaxSize == front

队列为空的条件依然是:

front == rear

入队为:

rear = (rear+1)%MaxSize

出队为:

front = (front+1)%MaxSize

获取队列中元素的个数:

(rear-front+MaxSize)%MaxSize

6、链队列(使用单链表来实现队列)

1 使用无头结点的单链表表示队列
2 表头为队头,表尾为队尾
3 设置头尾指针,方便对表的两端进行操作

初始时:front = NULL;rear = NULL;
链队列的基本操作:

**1 入队:**
if(rear == NULL)//原来的队列就是空的front = rear = newnode;//入队元素不但是队首也是队尾
else{rear->next = newnode;//在队尾入队rear = rear->next;//修改队尾指针
}
**2 出队:**
需要考虑队列是否为空、队列是否只有一个元素
if(队列为空)退出
else队列非空那么需要
node* p = front;
value = front->data;//保存队首元素
front = front->next;//在队首出队
free(p);
//如果原来只有一个元素,那么出队之后为空
if(front == NULL)	rear = NULL;//修改队尾指针
return value;

2 典型题目

请添加图片描述

请添加图片描述

请添加图片描述

注意:数组A的长度为m+1
请添加图片描述

注意:队列中只有一个元素的情况
请添加图片描述

请添加图片描述

请添加图片描述

请添加图片描述

请添加图片描述

3 算法题目

1、
使用两个栈来模拟队列
请添加图片描述
2、
请添加图片描述
入队:

Queue Queue_in(Queue Q,int e){//如果队列不为空,并且rear等于frontif((Q.tag == 1)&&(Q.rear == Q.front)){//打印队列已满printf("队列已满\n");}else{//入队Q.rear = (Q.rear+1)%m;Q.data[Q.rear] = e;if(Q.tag == 0)Q.tag = 1;//队列已经不为空}return Q;
}

出队:

ElemType Queue_out(Queue Q){if(Q.tag == 0)printf("队列为空\n");//退出else{Q.front = (Q.front+1)%m;e = Q.data[Q.front];if(Q.front == Q.rear)	Q.tag = 0;//空队列}return e;
}

3、
请添加图片描述
入队:

Queue Queue_in(Queue Q,int e){//表示队满if(Q.length == m)return 0;else{Q.rear = (Q.rear+1)%m;Q.data[Q.rear] = e;Q.length++;}return Q;
}

出队:

ElemType Queue_out(Queue Q){if(Q.length == 0)//队列为空return 0;else{int front = (Q.rear-Q.length+1+m)%m;//获取队头元素Q.length--;return Q.data[Q.front];}
}

相关内容

热门资讯

苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
蓝色爱心是什么意思 女生给男生... 人类是由男女两种性别组成的,两性之间的话题永远都有着最高的热度,而爱心常常用来比喻沐浴在爱情中男女彼...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...
苗族的传统节日 贵州苗族节日有... 【岜沙苗族芦笙节】岜沙,苗语叫“分送”,距从江县城7.5公里,是世界上最崇拜树木并以树为神的枪手部落...
北京的名胜古迹 北京最著名的景... 北京从元代开始,逐渐走上帝国首都的道路,先是成为大辽朝五大首都之一的南京城,随着金灭辽,金代从海陵王...
白皮书是什么意思 新疆7个白皮... 国务院新闻办公室今天(21日)发表《新疆的若干历史问题》白皮书。全文如下:新疆的若干历史问题(201...
应用未安装解决办法 平板应用未... ---IT小技术,每天Get一个小技能!一、前言描述苹果IPad2居然不能安装怎么办?与此IPad不...
脚上的穴位图 脚面经络图对应的... 人体穴位作用图解大全更清晰直观的标注了各个人体穴位的作用,包括头部穴位图、胸部穴位图、背部穴位图、胳...
长白山自助游攻略 吉林长白山游... 昨天介绍了西坡的景点详细请看链接:一个人的旅行,据说能看到长白山天池全凭运气,您的运气如何?今日介绍...
demo什么意思 demo版本... 618快到了,各位的小金库大概也在准备开闸放水了吧。没有小金库的,也该向老婆撒娇卖萌服个软了,一切只...
猫咪吃了塑料袋怎么办 猫咪误食... 你知道吗?塑料袋放久了会长猫哦!要说猫咪对塑料袋的喜爱程度完完全全可以媲美纸箱家里只要一有塑料袋的响...
世界上最漂亮的人 世界上最漂亮... 此前在某网上,选出了全球265万颜值姣好的女性。从这些数量庞大的女性群体中,人们投票选出了心目中最美...