数据结构day6链式队列

主程序

#include "fun.h"

int main(int argc, const char *argv[])

{

que_p Q=create();

enqueue(Q,10);

enqueue(Q,20);

enqueue(Q,30);

enqueue(Q,40);

enqueue(Q,50);

show_que(Q);

dequeue(Q);

show_que(Q);

printf("len:%d\n",que_len(Q));

free_que(Q);

Q=NULL;

show_que(Q);

return 0;

}

源程序

#include "fun.h"

que_p create()

{

que_p Q=(que_p)malloc(sizeof(que));

if(Q==NULL)

{

printf("error\n");

return NULL;

}

node_p H=(node_p)malloc(sizeof(node));

if(H==NULL)

{

printf("error\n");

free(Q);

Q=NULL;

return NULL;

}

H->next=NULL;

H->len=0;

Q->head=H;

Q->tail=H;

return Q;

}

int empty_que(que_p Q)

{

if(Q==NULL)

{

printf("error\n");

return -1;

}

return Q->head==Q->tail;

}

node_p create_new(typdata data)

{

node_p new =(node_p)malloc(sizeof(node));

if(new==NULL)

{

printf("error");

}

new->data=data;

new->next=NULL;

return new;

}

void enqueue(que_p Q,typdata data)

{

if(Q==NULL)

{

printf("erro\n");

}

node_p new=create_new(data);

Q->tail->next=new;

Q->tail=new;

Q->head->len++;

}

void show_que(que_p Q)

{

if(Q==NULL)

{

printf("error\n");

return;

}

if(empty_que(Q))

{

printf("Queue empty\n");

return;

}

node_p H=Q->head;

while(H->next!=NULL)

{

H=H->next;

printf("%-4d",H->data);

}

putchar(10);

}

void dequeue(que_p Q)

{

if(Q==NULL)

{

printf("error\n");

return;

}

if(empty_que(Q))

{

printf("Queue empty\n");

return;

}

printf("dequeue:%d\n",Q->head->next->data);

node_p p=Q->head->next;

Q->head->next=Q->head->next->next;

free(p);

p=NULL;

Q->head->len--;

}

int que_len(que_p Q)

{

if(Q==NULL)

{

printf("error\n");

return-1;

}

return Q->head->len;

}

void free_que(que_p Q)

{

if(Q==NULL)

{

printf("error\n");

return;

}

while(Q->head->next!=NULL)

{

dequeue(Q);

}

free(Q->head);

Q->head=NULL;

free(Q);

Q=NULL;

}

头文件

#ifndef _FUN_H

#define _FUN_H

#include <myhead.h>

typedef int typdata;

typedef struct node

{

union

{

int len;

typdata data;

};

struct node *next;

}node,*node_p;

typedef struct queue

{

node_p head;

node_p tail;

}que,*que_p;

que_p create();

int empty_que(que_p Q);

node_p create_new(typdata data);

void enqueue(que_p Q,typdata data);

void show_que(que_p Q);

void dequeue(que_p Q);

int que_len(que_p Q);

void free_que(que_p Q);

#endif

相关推荐
Helibo4418 分钟前
GESPC++六级复习
java·数据结构·算法
EnticE15243 分钟前
[高阶数据结构]二叉树经典面试题
数据结构·算法·面试
_星辰大海乀2 小时前
数据库约束
java·数据结构·数据库·sql·链表
爱喝茶的小茶2 小时前
构造+简单树状
数据结构·算法
小王努力学编程3 小时前
高并发内存池(三):TLS无锁访问以及Central Cache结构设计
jvm·数据结构·c++·学习
草莓啵啵~3 小时前
数据结构--二叉树
数据结构
Watink Cpper4 小时前
[数据结构高阶]并查集初识、手撕、可以解决哪类问题?
数据结构·图论··并查集
什码情况5 小时前
星际篮球争霸赛/MVP争夺战 - 华为OD机试真题(A卷、Java题解)
java·数据结构·算法·华为od·面试·机试
.Vcoistnt5 小时前
Codeforces Round 1024 (Div. 2)(A-D)
数据结构·c++·算法·贪心算法·动态规划·图论
程序员爱钓鱼5 小时前
循环语句:for、range -《Go语言实战指南》
java·数据结构·算法