#include <stdio.h>
#include <stdlib.h>
#define MAX_SIZE 5
typedef int elemType;
typedef struct {
elemType* base;
int front;
int rear;
}SqQueue;
void initQueue(SqQueue* S)
{
S->base = (elemType*)malloc(sizeof(elemType) * MAX_SIZE);
if (!S->base) exit(1);
else S->front = S->rear = 0;
}
int getLength(SqQueue* S)
{
return (S->rear - S->front + MAX_SIZE) % MAX_SIZE;
}
void insertElem(SqQueue* S, elemType data)
{
if ((S->rear + 1) % MAX_SIZE == S->front)
{
printf("队列空间已满,插入元素失败!");
}
else
{
S->base[S->rear] = data;
printf("插入成功:%d\n", S->base[S->rear]);
S->rear = (S->rear + 1) % MAX_SIZE;
}
}
void deleteElem(SqQueue* S)
{
if (S->front == S->rear)
{
printf("空队列,删除元素失败!\n");
}
else
{
printf("删除了队首元素:%d\n", S->base[S->front]);
S->front = (S->front + 1) % MAX_SIZE;
}
}
void printdui(SqQueue a) {
if (a.front==a.rear)
return -1;
if (a.front < a.rear) {
for (int i = a.front; i < a.rear; i++)
printf("%d ", a.base[i]);
}
else {
for (int i = a.front; i < a.rear + MAX_SIZE; i++)
printf("%d ", a.base[i % MAX_SIZE]);
}
printf("\n");
return 0;
}
int main()
{
printf("队列最大空间为5,存放元素个数为4\n");
SqQueue S;
initQueue(&S);
insertElem(&S, 5);
insertElem(&S, 6);
insertElem(&S, 7);
insertElem(&S, 8);
insertElem(&S, 9);
printf("\n此时队列共有%d个元素\n", getLength(&S));
printdui(S);
deleteElem(&S);
deleteElem(&S);
printf("\n此时队列共有%d个元素\n", getLength(&S));
printdui(S);
insertElem(&S, 3);
insertElem(&S, 4);
printf("\n此时队列共有%d个元素\n", getLength(&S));
printdui(S);
return 0;
}
