队列:SeqQueue(循环队列/顺序队列)的全代码

本文详细介绍了在C语言中如何使用结构体和函数实现顺序队列,包括创建空队列、判空、入队、出队和获取队头的操作,特别提到了循环队列的处理方式以避免空间浪费。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

C语言版:

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

typedef int DataType;
struct Queue
{
    int Max;
    int f,r;
    DataType *elem;
};
typedef struct Queue *SeqQueue; // 加typedef使其另起别名

SeqQueue SetNullQueue_Seq(int m)
{
    SeqQueue squeue;
    squeue = (SeqQueue)malloc(sizeof(struct Queue));
    if(squeue == NULL)
    {
        printf("Alloc failure!\n");
        return NULL;
    }
    else
    {
        squeue ->elem  = (int *)malloc(sizeof(DataType) * m);
        if(squeue ->elem != NULL) // 分配好内存此时指针就不为空
        {
            squeue ->Max = m;
            squeue ->f = 0;
            squeue ->r = 0;
            return squeue;
        }
    }
}

int IsNullQueue_seq(SeqQueue squeue)
{
    return(squeue ->f == squeue ->r);
}

void EnQueue_seq(SeqQueue squeue, DataType x)
{
    if((squeue ->r + 1) % squeue -> Max == squeue ->f) // 判断队满
    {
        printf("It is FULL Queue!");
    }
    else
    {
        squeue ->elem[squeue ->r] = x;
        squeue ->r = (squeue ->r + 1) % (squeue ->Max); // 循环队列的写法
    }
}

void DeQueue_seq(SeqQueue squeue)
{
    if(IsNullQueue_seq(squeue))
    {
        printf("It is empty queue!\n");
    }
    else
    {
        squeue ->f = (squeue ->f + 1) % (squeue ->Max);
    }
}

DataType FrontQueue_seq(SeqQueue squeue)
{
    if(IsNullQueue_seq) // 判空
    {
        printf("It is empty queue!");
    }
    else
    {
        return(squeue ->elem[squeue ->f]);
    }
}


int main()
{
    SetNullQueue_Seq(int m);                  // 建立空队列
    IsNullQueue_seq(SeqQueue squeue);         // 判空
    EnQueue_seq(SeqQueue squeue, DataType x); // 入队
    DeQueue_seq(SeqQueue squeue);             // 出队
    FrontQueue_seq(SeqQueue squeue);          // 取队头
    return 0;
}

 /*
    注:这里的顺序队列实际上是指循环队列,因为一般的循环队列会导致假溢出的情况发生,
    使内存不能完全使用,造成空间的浪费
*/

/************************************************************* date: April 2017 copyright: Zhu En DO NOT distribute this code without my permission. **************************************************************/ // 循环顺序队列实现文件 ///////////////////////////////////////////////////////// #include <stdio.h> #include <stdlib.h> #include "SeqQueue.h" SeqQueue* SQ_Create(int maxlen) // 创建顺序队列, 队列最多存储maxlen个队列元素。 { SeqQueue* sq=(SeqQueue*)malloc(sizeof(SeqQueue)); sq->data=(T*)malloc(sizeof(T)*(maxlen+1)); sq->front=sq->rear=0; sq->max=maxlen+1; return sq; } void SQ_Free(SeqQueue* sq) // 释放队列空间,以删除队列。 { free(sq->data); free(sq); } void SQ_MakeEmpty(SeqQueue* sq) // 将队列置空。 { sq->front=0; sq->rear=0; } bool SQ_IsEmpty(SeqQueue* sq) // 判断队列是否为空,为空返回true,否则返回false。 { // 请在Begin-End之间补充代码,完成队列是否为空的判断。 /********** Begin *********/ /********** End **********/ } bool SQ_IsFull(SeqQueue* sq) // 判断队列是否为满。为满返回true,否则返回false。 { // 请在Begin-End之间补充代码,完成队列是否为满的判断。 /********** Begin *********/ /********** End **********/ } int SQ_Length(SeqQueue* sq) // 队列长度。 { // 请在Begin-End之间补充代码,获取队列长度。 /********** Begin *********/ /********** End **********/ } bool SQ_In(SeqQueue* sq, T x) // 将x入队。若入队失败(队列),则返回false,否则返回true。 { // 请在Begin-End之间补充代码,将 x 入队。 /********** Begin *********/ /********** End **********/ } bool SQ_Out(SeqQueue* sq, T& item) // 从队列sq出队一个元素,返回时item为出队的元素的值。若出队成功(队列不为空),则返回true,否则(队列),返回false,此时item不会返回有效值。 { // 请在Begin-End之间补充代码,完成元素出队操作。 /********** Begin *********/ /********** End **********/ } bool SQ_Head(SeqQueue* sq, T& head) // 获取队列头结点元素,返回时head保存头结点元素。 // 若获取失败(队列),则返回值为false,否则返回值为true。 { if ( SQ_IsEmpty(sq) ){ return false; } else { head = sq->data[sq->front]; return true; } } void SQ_Print(SeqQueue* sq) // 依次打印出队列中的每个元素。 { int i=sq->front; if (SQ_IsEmpty(sq)) { printf("queue is emtpy")
最新发布
03-30
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值