C语言实现循环队列

C语言实现循环队列

main.c

#include "test.h"

void test();

ElementType dataArray[] = {
    {1,"侠客行"},
    {2,"将进酒"},
    {3,"神来之笔"},
    {4,"青莲剑歌"}
};

int main()
{
    test();
    return 0;
}


void test(){
    SeqQueue seq;
    InitSeqQueue(& seq);
    for (int i=0;i < 4;i++){
        OfferSeqQueue(&seq,dataArray[i]);
    }
    for (int i=0;i < seq.length;i++){
        printf("%d\t%s.\n",seq.data[i].id,seq.data[i].name);
    }
    ElementType element;
    printf("\n");
    PollSeqQueue(&seq,&element);
    printf("出队元素:%d\t%s.\n\n",element.id,element.name);
    for (int i=seq.front;i < seq.rear;i++){
        printf("%d\t%s.\n",seq.data[i].id,seq.data[i].name);
    }
}

test.h

#ifndef TEST_H_INCLUDED
#define TEST_H_INCLUDED

#include <stdio.h>
#include <stdlib.h>

#define MAX_SIZE 10
#define STATE_OK 1
#define STATE_FAILD -1
#define TRUE 2
#define FALSE 0

typedef int State;  //给整形起别名,专门用来表示状态

typedef struct {
    int id;
    char * name;
}ElementType;

//循环队列结构
typedef struct {
    ElementType data[MAX_SIZE];
    int front;
    int rear;
    int length;
}SeqQueue;

//初始化队列
void InitSeqQueue(SeqQueue * seqqueue);

State IsEmpety(SeqQueue * seqqueue);

State IsFull(SeqQueue * seqqueue);

//入队
State OfferSeqQueue(SeqQueue * seqqueue,ElementType element);

//出队
State PollSeqQueue(SeqQueue * seqqueue,ElementType * element);

#endif // TEST_H_INCLUDED

test.c

#include "test.h"

//初始化
void InitSeqQueue(SeqQueue * seqqueue){
    if (seqqueue == NULL){
        seqqueue = (SeqQueue *)malloc(sizeof(SeqQueue));
    }
    seqqueue->length = 0;
    seqqueue->front = 0;
    seqqueue->rear = 0;
}

State IsEmpety(SeqQueue * seqqueue){
    return seqqueue->front == seqqueue->rear ? TRUE:FALSE;
}

State IsFull(SeqQueue * seqqueue){
    if (seqqueue->front == (seqqueue->rear + 1)%MAX_SIZE){
        return TRUE;
    }
    return FALSE;
}


//入队
State OfferSeqQueue(SeqQueue * seqqueue,ElementType element){
    if (IsFull(seqqueue)){
        return STATE_FAILD;
    }
    seqqueue->data[seqqueue->rear] = element;
    seqqueue->rear = (seqqueue->rear + 1) % MAX_SIZE;
    seqqueue->length++;
    return STATE_OK;
}


//出队
State PollSeqQueue(SeqQueue * seqqueue,ElementType * element){
    if (IsEmpety(seqqueue)){
        return STATE_FAILD;
    }
    *element = seqqueue->data[seqqueue->front];
    seqqueue->front = (seqqueue->front + 1) % MAX_SIZE;
    seqqueue->length--;
    return STATE_OK;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值