数据结构:链式队列尝试;0826

链式队列

尝试了 没写出来。代码存档,如下

queuelink.c

复制代码
#include"queue.h"
//1.申请 链式队列
queuelink_p creatlink()
{
	//申请 链表 头尾指针 结构体空间
	queuelink_p H=(queuelink_p)malloc(sizeof(queuelink));
	if(H==NULL)//申请空间失败
	{
		printf("申请空间失败\n");
		return NULL;
	}
	
	
	H->front=NULL;
	H->rear=NULL;

	return H;
}
//1.1申请 节点
queue_p creat_node(int V)
{
	//申请 链表 头尾指针 结构体空间
        queue_p N=(queue_p)malloc(sizeof(queue));
        if(N==NULL)//申请空间失败
        {
                printf("申请空间失败\n");
                return NULL;
        }
	N->data=V;
	N->next==NULL;

	return N;
}
//2.判空
int empty(queuelink_p H)
{       
	if(H==NULL)//入参为空
        {       
                printf("入参为空\n");
                return -1;
        }
	return H->front==NULL&&H->rear==NULL;
}
//4.入队
void push_rear(queuelink_p H,int V)
{       
	if(H==NULL)//入参为空
        {
                printf("入参为空\n");
                return ;
        }
	//申请节点
	queue_p N=creat_queue(V);
	//节点链接 入队 队尾
	if(H->front=NULL)
	{
		H->front=N;
	}
	if(H->rear!=NULL)
	{
		H->rear->next=N;
	}
	H->next=N;
}
//5.出队
int pop_que(queue_p H)
{       
	if(H==NULL)//入参为空
        {
                printf("入参为空\n");
                return ;
        }
	//判断队列为空
	if(empty(H))
	{
		printf("队列为空\n");
		return;
	}
	//出队 队头出
	queue_p D=H->front;
	//队头 指针 指向下一个
	H->front=H->front->next;

	//保留 出队的值
	int ret=D->data;
	//释放空间
	free(D);

	return ret;
}
//6.输出
void show_que(queuelink_p H)
{
	if(H==NULL)//入参为空
        {
                printf("入参为空\n");
                return ;
        }
        //判断队列为空
        if(empty(H))
        {
                printf("队列为空\n");
                return;
        }
        //S指针 输出值
        queue_p S=H->front;
        while(S!=NULL)
        {
                printf("%d ",S->data);
                S=S->next;
        }
}
//7.求队列元素个数
int count_que(queuelink_p H);
//8.释放循环队列
void free_que(queuelink_p *H);

main.c

复制代码
#include"queue.h"
int main()
{
	//1.申请队列
	queuelink_p H =creatlink();
	//4.入队
	for(int i=9;i>4;i--)
	{
	push_rear(H,i);
	}
	//5.出队
	printf("出队的值为%d\n",pop_que(H));

	//6.输出
	show_que(H);

	return 0;
}

queue.h

复制代码
#ifndef __QUEUE_H_ 
#define __QUEUE_H_ 1

#include<stdio.h>
#include<stdlib.h>

//链栈的节点 结构体
typedef struct node
{
	int data;
	struct node *next;
}queue,*queue_p;

//链式队列 头 结构体
typedef struct queuelink
{
	struct node *front;
	struct node *rear;
}queuelink,*queuelink_p;

//1.申请队列
queuelink_p creatlink();
//1.1申请节点
queue_p creat_node(int);
//2.判空
int empty(queuelink_p);
//4.入队
void push_rear(queuelink_p,int);
//5.出队
int pop_que(queuelink_p);
//6.输出
void show_que(queuelink_p);
//7.求队列元素个数
int count_que(queuelink_p);
//8.释放循环队列
void free_que(queuelink_p *);

#endif

兄弟,是报错

牛客刷题

相关推荐
2601_961875246 分钟前
法考资料2026|全套|资料已整理
数据结构·算法·链表·贪心算法·eclipse·线性回归·动态规划
dtq04243 小时前
C语言刷题数组5,6(求平均值,求最大值)
c语言·数据结构·算法
洛水水4 小时前
【力扣100题】81.寻找两个正序数组的中位数
数据结构·算法·leetcode
Coder-magician4 小时前
《代码随想录》刷题打卡day15:二叉树part05
数据结构·c++·算法
Darling噜啦啦4 小时前
二叉树与递归算法实战:从树结构到 LeetCode 爬楼梯,一文吃透前端数据结构与递归思维
前端·javascript·数据结构
Irissgwe5 小时前
算法的时间复杂度和空间复杂度
数据结构·c++·算法·c·时间复杂度·空间复杂度
退休倒计时5 小时前
【每日一题】LeetCode 19. 删除链表的倒数第 N 个结点 TypeScript
leetcode·链表·typescript
qq_297574676 小时前
设计模式系列文章(基础篇第22篇):访问者模式——分离数据结构与操作,实现灵活扩展
数据结构·设计模式·访问者模式
云淡风轻~窗明几净6 小时前
角谷猜想的任意算法测试
数据结构·人工智能·算法
代码中介商6 小时前
关键路径解析:项目管理的工期奥秘
数据结构