队列的C语言实现

 1 #include <stdio.h>
 2 #include <stdlib.h>
 3 #include <assert.h>
 4 typedef struct node{//定义双向链表节点
 5     int data;
 6     struct node *pNext;
 7 }*pNODE,NODE;
 8 typedef struct head{//定义队列头节点
 9     pNODE pHead;
10     pNODE pTail;    
11 }*pHEAD,HEAD;
12 pHEAD Create(){
13     pHEAD pHead=NULL;
14     pHead=(pHEAD)malloc(sizeof(HEAD));
15     assert(pHead);
16     pHead->pHead=NULL;
17     pHead->pTail=NULL;
18     return pHead;
19 }
20 void PutData(pHEAD head,int data){
21     pNODE pNode=NULL;
22     pNode=(pNODE)malloc(sizeof(NODE));
23     assert(pNode);
24     pNode->data=data;
25     pNode->pNext=NULL;
26     if (head->pTail)//如果队尾不为空,则让原队尾节点指针指向新节点
27         head->pTail->pNext=pNode;
28     head->pTail=pNode;
29     if(head->pHead==NULL)//当队列为空时,添加新结点后要修改头指针.
30         head->pHead=pNode;
31 }
32 int GetData(pHEAD head){
33     int data;
34     pNODE pNode=NULL;
35     pNode=head->pHead;
36     assert(pNode);
37     head->pHead=pNode->pNext;
38     data=pNode->data;
39     free(pNode);
40     return data;
41 }
42 int main(){
43     pHEAD head=NULL;
44     head=Create();
45     PutData(head,1);
46     PutData(head,2);
47     PutData(head,3);
48     PutData(head,4);
49     printf("%d\t",GetData(head));
50     printf("%d\t",GetData(head));
51     printf("%d\t",GetData(head));
52     printf("%d\t",GetData(head));
53 }

程序通过在线测试:

http://ideone.com/qXl964

转载于:https://www.cnblogs.com/OneL1fe/p/6529747.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值