zoukankan      html  css  js  c++  java
  • 队列的链式实现(C语言)

    /* Queue.h */
    
    #ifndef QUEUE_H_INCLUDED
    #define QUEUE_H_INCLUDED
    #include <stdio.h>
    #include <stdlib.h>
    
    struct Queue_Array {
        int element;
        struct Queue_Array* next;
    };
    typedef struct Queue_Array* Q_Array;
    
    struct _Queue {
        Q_Array q;
        Q_Array Front;
        Q_Array Rear;
    };
    
    typedef struct _Queue* Queue;
    
    /* Queue Operation */
    int isEmpty(Queue Q);
    void CreateQueue(Queue Q);
    void make_Queue_Empty(Queue Q);
    void Enqueue(int Elmt, Queue Q);
    int Front(Queue Q);
    void Dequeue(Queue Q);
    int FrontAndDequeue(Queue Q);
    void printQueue(Queue Q);
    
    #endif // QUEUE_H_INCLUDED
    /* Queue.c */
    
    #include "Queue.h"
    
    int isEmpty(Queue Q) {
    	return (Q->Front == Q->Rear);
    }
    
    void CreateQueue(Queue Q) {
    
        Q_Array q   =   (Q_Array)malloc(sizeof(struct Queue_Array));
        q->element  =   0;
        q->next     =   NULL;
        Q->Front    =   Q->Rear = q;
    }
    
    void Enqueue(int Elmt, Queue Q) {
    
        Q_Array q       =   (Q_Array) malloc (sizeof(struct Queue_Array));
        q->element      =   Elmt;
        q->next         =   NULL;
        Q->Rear->next   =   q;
        Q->Rear         =   q;
    }
    
    int Front(Queue Q) {
        return Q->Front->element;
    }
    
    void Dequeue(Queue Q) {
    
        Q_Array q   = Q->Front;
        Q->Front    = Q->Front->next;
        free(q);
    
    }
    
    int FrontAndDequeue(Queue Q) {
    
        int frontElmt;
        Q_Array q   =   Q->Front;
        frontElmt   =   q->element;
        Q->Front    =   Q->Front->next;
        free(q);
        return frontElmt;
    }
    
    void make_Queue_Empty(Queue Q) {
    
        Q_Array q = Q->Front;
    
        while(q != Q->Rear) {
    
            Q->Front = Q->Front->next;
            free(q);
            q = Q->Front;
        }
    
        Q->Front = Q->Rear = NULL;
        Q->q     =   NULL;
        free(q);
    }
    
    void printQueue(Queue Q) {
    
        Q_Array q = Q->Front;
    
        while (q != Q->Rear->next) {
    
            printf("%d ", q->element);
            q = q->next;
        }
        printf("
    ");
    }
    


    测试:

    /* main.c */
    
    #include "Queue.h"
    
    int main()
    {
        Queue Q  = (Queue) malloc (sizeof(struct _Queue));
        Q->Front = NULL;
        Q->q     = NULL;
        Q->Rear  = NULL;
    
        CreateQueue(Q);
    
        Enqueue(1, Q);
        Enqueue(3, Q);
        Enqueue(5, Q);
        Enqueue(7, Q);
        Enqueue(9, Q);
        Enqueue(11, Q);
    
        printQueue(Q);
        Dequeue(Q);
        printQueue(Q);
    
        printf("Queue's front element is %d
    ", Front(Q));
        FrontAndDequeue(Q);
        printf("Queue's front element is %d
    ", Front(Q));
    
        printQueue(Q);
        return 0;
    }


    结果:




  • 相关阅读:
    Python基础学习参考(四):条件与循环
    Python基础学习参考(三):内置函数
    Python基础学习参考(二):基本语法
    2011的最后一篇博文 写给我自己也写给你们
    前端开发面试题
    常用js操作:
    两个嵌套for循环执行顺序
    在寻找学习js的途中,又发现了好的东西!
    arcgis api for js初学
    解决为什么arcgis api for js的first map里不显示arcgis地图
  • 原文地址:https://www.cnblogs.com/averson/p/5096050.html
Copyright © 2011-2022 走看看