- c++中的STL是非常好用的。这里使用数组的形式或结构体的形式加深理解。
- 首先,介绍数组的形式,,将“6 3 1 7 5 8 9 2 4”这 9个数分别写在 9张便签上模拟这样的规则,规则是这样的:首先将第 1个数删除,紧接着将第 2个数放到 这串数的末尾,再将第 3个数删除并将第 4个数放到这串数的末尾,再将第 5个数删除…… 直到剩下后一个数,将后一个数也删除。
- 引入两个整型变量 head 和 tail。head 用来记录队列的队首(即第一位), tail 用来记录队列的队尾(即后一位)的下一个位置。你可能会问:为什么 tail 不直接记 录队尾,却要记录队尾的下一个位置呢?这是因为当队列中只剩下一个元素时,队首和队尾重合会带来一些麻烦。我们这里规定队首和队尾重合时,队列为空。
其次,使用结构体的形式,定义一个结构体类型。

代码:
#include<iostream>
using namespace std;
/*这是第一种用数组的形式;
int main(){
int p[102]={0,6,3,1,7,5,8,9,2,4},head,tail;
int i;
head=1;
tail=10;
while(head<tail){
cout<<p[head]<<" ";
head++;
p[tail]=p[head];
tail++;
head++;
}
return 0;
}
*/
//以下是结构体类型写的:
struct queue{
int data[100];
int head;
int tail;
};
int main(){
struct queue q;
q.head=1;
q.tail=1;
for(int i=1;i<=9;i++){
cin>>q.data[q.tail];
q.tail++;
}
while(q.head<q.tail){
cout<<q.data[q.head]<<" ";
q.head++;
q.data[q.tail]=q.data[q.head];
q.tail++;
q.head++;
}
return 0;
}