rear++: 出队, front++
队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈一样,队列是一种操作受限制的线性表。进行插入操作的端称为队尾,进行删除操作的端称为队头。
双端队列 (可以理解为中间站了一个人,push和pop就在他左边进行,而inject和eject在他右边进行)
注意:双端队列使用了循环队列。判断满不满的条件是多开一个空间,即判断rear与front的关系。
我们rear指针指向元素的下一个空位置,front指向元素
- push 将元素插入表头 front- -
- pop 删除头部元素 front++
- inject 将元素插入到表尾 rear++
- eject 删除尾部元素 rear- -
- 初始化时,rear=front=0;
有- - 操作,可能会出现负值,所以需要+size在取余的操作
复制代码
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101#include<stdio.h> #include<stdlib.h> typedef struct QNode{ int *Data; int Front,Rear; int MaxSize;// 队列最大容量 }QNode,*Deque; Deque CreateDeque( int MaxSize ) { /* 注意:为区分空队列和满队列,需要多开辟一个空间 */ Deque D = (Deque)malloc(sizeof(struct QNode)); MaxSize++; D->Data = (int *)malloc(MaxSize * sizeof(int)); D->Front = D->Rear = 0; D->MaxSize = MaxSize; return D; } bool Push( int X, Deque D ) { if((D->Rear+1)%D->MaxSize==D->Front) return false;//空间满了,我们有一个空间不用 D->Front--;//push就是往左边插入,所以- - D->Front=(D->Front+D->MaxSize)%D->MaxSize;//- -之后万一出界呢?所以要取余 D->Data[D->Front]=X;//解决了出界问题后,我们就可以把这个元素放到这里了 return true; } int Pop( Deque D ) { if(D->Front==D->Rear) return 0;//队列空 int x=D->Data[D->Front];//pop是删除头部元素,即front所在位置的元素 ++D->Front;//删除了,就要+ + D->Front=D->Front%D->MaxSize;//防止他出界 return x; } bool Inject( int X, Deque D )//插入结点 { if((D->Rear+1)%D->MaxSize==D->Front) return false;//空间满 D->Data[D->Rear]=X;//rear是尾部元素下一个空间,所以把新元素放到这里就行 D->Rear++;//rear还要指向尾部的下一个空间 D->Rear=D->Rear%D->MaxSize; //防止他出界 return true; } int Eject( Deque D )//删除节点 并返回 { if(D->Front==D->Rear) return 0;//队列空 D->Rear--;//eject是删除尾部元素,由于rear是尾部元素下一个空间,所以- - D->Rear=(D->Rear+D->MaxSize)%D->MaxSize;//防止出界 int x=D->Data[D->Rear];//返回尾部元素,此时rear指向,我们可以认为是空位置 return x; } bool IsEmpty(Deque D) { if(D->Front==D->Rear) return true; return false; } bool IsFull(Deque D) { if(D->Front+D->Rear==D->MaxSize-1) return true; return false; } //void show(Deque D) //{ // int i; // for(i=(D->Front+1)%D->MaxSize;i<=D->Rear;i++) // printf("%d ",D->Data[i]); // //} int main(){ int x,n; QNode Q,*D; scanf("%d",&n); D=CreateDeque(n); for(int i=0;i<n;i++) { scanf("%d",&x); Push(x,D); } int y=Pop(D); printf("%dn",y); printf("插入元素:"); scanf("%d",&x); Inject(x,D); // printf("显示队列元素n"); // show(&Q); printf("删除队尾元素n"); Eject(D); while(!IsEmpty(D)) { y=Pop(D); printf("%d ",y); } // printf("显示队列元素:n"); // show(D); return 0; }
最后
以上就是温暖外套最近收集整理的关于双端队列的全部内容,更多相关双端队列内容请搜索靠谱客的其他文章。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复