教大家怎样写队列?

学习日志3
姓名:缪志超 日期:2018.9.12

今日学习任务
1、队列的顺序
2、链式存储
3、空对:队头队尾重合
4、队尾指针:指向最后一个元素的后一个
5、自定义函数来实现初始化,清空,输入,输出,删除,销毁等一系列操作

今日任务完成情况
1、按照课上老师的要求已经全部完成了所有的任务,并且实现了调试。
2、今天的代码开发量已经达到400多行。

今日开发中出现的问题
今天开发中出现的问题自己都能独立解决。

今日开发收获
1、学会了如何初始化,清空,输入,输出,删除,销毁等一系列操作
2、学会了如何队列的顺序存储

自我感觉
感觉不错,每天都能学到一些在学校学不到的知识,有成为程序员的潜力。

程序代码
下面我将我今天写的程序与大家共勉,如有错误还请大家指出,谢谢!
1、首先建一个文件名:queue.c

#include "queue.h"
#include <stdlib.h>
int InitQueue(Q *q)
{
    if(NULL == q)      //入参判断
    {
        return FAILURE;
    }
    //申请一块内存空间 ,并且让 data 指针指向 这块空间 
    q->data = (int *)malloc(sizeof(int)*MAXSIZE);
    if(NULL == q->data)        //返回值判断(如果申请失败 )
    {
        return FAILURE;
    }

    q->rear = q->front = 0;   //队头队尾 指针指向同一个
    return SUCCESS;
}

int EnterQueue(Q *q,int e)
{
    if(NULL == q)
    {
        return FAILURE;
    }
    if((q->rear + 1) % MAXSIZE == q->front)  // 队满
    {
        return FAILURE;
    }
    q->data[q->rear] = e;
    q->rear = (q->rear + 1) % MAXSIZE;

    return SUCCESS;
}

int DelQueue(Q *q)
{
    if(NULL == q)
    {
        return FAILURE;
    }
    if(q->rear == q->front)       //空队
    {
        return FAILURE;
    }
    int e = q->data[q->front];
    q->front = (q->front + 1) % MAXSIZE;
    return e;
}

int LengthQueue(Q q)
{
    return (q.rear - q.front + MAXSIZE) % MAXSIZE;
}

int ClearQueue(Q *q)
{
    if(NULL == q)
    {
        return FAILURE;
    }
    q->rear = q->front;
    return SUCCESS;
}


int DestroyQueue(Q *q)
{
    if(NULL == q)
    {
        return FAILURE;
    }
    free(q->data);               //释放空间
    q->data = NULL;
    return SUCCESS;
}

再建一个文件名:main.c

#include <stdio.h>
#include "queue.h"

int main()
{
    int i, ret;
    Q queue;    //定义队列

    ret = InitQueue(&queue);
    if(SUCCESS == ret)
    {
        printf("Init Success!\n");
    }
    else
    {
        printf("Init Failure!\n");
    }
    for(i=0;i<10;i++)
    {
        ret = EnterQueue(&queue,i+1);
        if(ret == FAILURE)
        {
            printf("Enter Failure!\n");
        }
        else
        {
            printf("Enter %d Success!\n",i+1);
        }

    }
    for(i=0;i<5;i++)
    {
        ret = DelQueue(&queue);
        if(ret == FAILURE)
        {
            printf("Delete Failure!\n");
        }
        else
        {
            printf("Delete %d Success!\n",ret);
        }
    }

    ret = LengthQueue(queue);
    printf("length is %d\n",ret);

    ret = ClearQueue(&queue);
    if(ret == SUCCESS)
    {
        printf("Clear Success!\n");
    }
    else
    {
        printf("Clear Failure!\n"); 
    }

    ret = DestroyQueue(&queue);
    if(ret == SUCCESS)
    {
        printf("Destroy Success!\n");
    }
    else
    {
        printf("Destroy Failure!\n");
    }
    return 0;
}

最后建一个文件名:queue.h

#ifndef QUEUE_H
#define QUEUE_H

#define MAXSIZE   10      //RONGLIANG
#define SUCCESS   1000
#define FAILURE   1001

struct queue
{
    int *data;        //指向队列的存储空间
    int front;       //队头指针
    int rear;        //队尾指针
};
typedef struct queue Q;

int InitQueue(Q *q);
int EnterQueue(Q *q,int e);
int DelQueue(Q *q);
int LengthQueue(Q q);
int ClearQueue(Q *q);
int DestroyQueue(Q *q);

#endif

输入命令:./a.out
调试结果 :这里写图片描述

2、链式存储

首先建一个文件名:queue.h

#ifndef QUEUE_H
#define QUEUE_H

#define SUCCESS  1000
#define FAILURE  1001

struct node     //结点的信息
{
    int data;   //数据域
    struct node *next;  //指针域
};
typedef struct node Node;

struct queue          //队列的信息
{
    Node *front;     //队头指针
    Node *rear;      //队尾指针
};
typedef struct queue Q;

int InitQueue(Q **q);
int EnterQueue(Q *q,int e);
int DeletQueue(Q *q);
int LengthQueue(Q *q);
int ClearQueue(Q *q);
int EmptyQueue(Q *q);
int DestroyQueue(Q **q);
#endif

再建一个文件名:main.c

#include "queue.h"
#include <stdio.h>

int main()
{
    int i, ret;
    Q *queue;

    ret = InitQueue(&queue);
    if(ret == SUCCESS)
    {
        printf("Init Success!\n");
    }
    else
    {
        printf("Init Failure!\n");
    }

    for (i=0;i<10;i++)
    {
        ret = EnterQueue(queue,i+1);
        if(ret == SUCCESS)
        {
            printf("Enter %d Success!\n",i+1);
        }
        else
        {
            printf("Enter Failure!\n");
        }
    }

    for (i=0;i<6;i++)
    {
        ret = DeleteQueue(queue);
        if(ret == FAILURE)
        {
            printf("Delete Failure!\n");
        }
        else
        {
            printf("Delete %d Success!\n",ret);
        }

    }

    ret = LengthQueue(queue);
    printf("length is %d\n",ret);

    ret = ClearQueue(queue);
    if(ret == SUCCESS)
    {
        printf("Clear Success!\n");
    }
    else
    {
        printf("Clear Failure!\n");
    }

    ret = LengthQueue(queue);
    printf("length is %d\n",ret);

    ret = EmptyQueue(queue);
    if(SUCCESS == ret)
    {
        printf("queue is empty!\n");
    }
    else
    {
        printf("queue is not empty!\n");
    }

    ret = DestroyQueue(&queue);
    if(ret == SUCCESS)
    {
        printf("Destroy Success!\n");
    }
    else
    {
        printf("Destroy Failure!\n");
    }
    return 0;
}

最后建一个文件名:queue.c

#include "queue.h"
#include <stdlib.h>

int InitQueue(Q **q)
{
    if (NULL == q)    //入参判断
    {
        return FAILURE;
    }

    (*q) = (Q *)malloc(sizeof(Q));  //gei dui lie xinxi shenqing kongjian   
    if(NULL == (*q))
    {
        return FAILURE;
    }

    Node *p = (Node *)malloc(sizeof(Node));//头结点申请空间
    if (NULL == p)
    {
        return FAILURE;
    }

    (*q)->front = (*q)->rear = p;//队头指针 队尾指针都指向头结点  

    return SUCCESS;
}

int EnterQueue(Q *q,int e)
{
    if(NULL == q)
    {
        return FAILURE;
    }

    Node *p = (Node *)malloc(sizeof(Node));
    if(NULL == p)
    {
        return FAILURE;
    }
    p->next = NULL;         //指针域
    p->data = e;           //数据域

    q->rear->next = p;
    q->rear = p;

    return SUCCESS;
}

int DeleteQueue(Q *q)
{
    if(NULL == q)
    {
        return FAILURE;
    }
    if(q->rear == q->front)     //空队
    {
        return FAILURE;
    }

    Node *p = q->front->next;
    int e = p->data;
    q->front->next = p->next;
    free(p);

    if(q->rear == p)      //只剩一个结点的情况
    {
        q->rear = q->front;
    }
    return e;
}

int LengthQueue(Q *q)
{
    if(NULL == q)
    {
        return FAILURE;
    }
    int length = 0;

    Node *p = q->front->next;
    while(p)         //while(p!=NULL)
    {
        length++;
        p = p->next;
    }
    return length;

}

int ClearQueue(Q *q)
{
    if(NULL == q)   //入参判断
    {
        return FAILURE;
    }

    Node *p = q->front->next;

    while(p)
    {
        q->front->next = p->next;
        free(p);                  //释放结点
        p = q->front->next;      //指向新的结点
    }

    q->rear = q->front;         //删完所有的结点,队尾指针指向开头

    return SUCCESS;
}

int EmptyQueue(Q *q)
{
    if(NULL == q)
    {
        return FAILURE;
    }

    return (q->front == q->rear) ? SUCCESS : FAILURE;

}

int DestroyQueue(Q **q)
{
    if(NULL == q)
    {
        return FAILURE;
    }
    free((*q)->front);       //释放头结点
    free(*q);            //释放队列信息
    *q = NULL;

    return SUCCESS;
}

调试命令:./a.out
调试结果:这里写图片描述

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值