隊列的C語言實現

來源:互聯網
上載者:User

標籤:資料結構   隊列   

隊列不同於棧,它是先進先出,即先入隊列的元素提取時也要先出隊列。隊列可以用數組實現也可以用鏈表實現,挺簡單的,但是很有些情況下很有用。它的實現只要維持好隊首和隊尾指標就好了。下面是我實現的鏈表隊列。

queue.h

#ifndef __QUEUE_H#define __QUEUE_H#include <stdio.h>#include <stdlib.h>struct QueueNode;struct queue;typedef Vertex ElementType;typedef struct QueueNode *Node;typedef struct queue *Queue;struct QueueNode{ElementType element;Node next;};struct queue{Node first;Node last;};Queue createQueue();int isEmpty(Queue Q);void EnQueue(ElementType X,Queue Q);ElementType DeQueue(Queue Q);void deleteQueue(Queue Q);#endif

queue.c

#include "queue.h"Queue createQueue(){Queue Q;Node node;node=(Node)malloc(sizeof(struct QueueNode));if(node==NULL){printf("out of space\n");exit(-1);}node->next=NULL;Q=(Queue)malloc(sizeof(struct queue));if(Q==NULL){printf("out of space\n");exit(-1);}Q->first=node;Q->last=node;return Q;}int isEmpty(Queue Q){if(Q->first==Q->last)return 1;elsereturn 0;}void EnQueue(ElementType X,Queue Q){Node node;node=(Node)malloc(sizeof(struct QueueNode));if(node==NULL){printf("out of space\n");exit(-1);}node->element=X;node->next=NULL;Q->last->next=node;Q->last=node;}ElementType DeQueue(Queue Q){ElementType x;Node p;if(isEmpty(Q)){printf("queue is empty\n");exit(-1);}p=Q->first->next;Q->first->next=p->next;x=p->element;if(p==Q->last){Q->last=Q->first;}free(p);return x;}void deleteQueue(Queue Q){while(!isEmpty(Q)){DeQueue(Q);}}


著作權聲明:本文為博主原創文章,未經博主允許不得轉載。

隊列的C語言實現

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.