- 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; }