C语言实现队列(链式存储)

开始学习c语言
在这里插入图片描述

#define true 1;
#define false 0;

/*定义最大队列的长度*/
#define MAX_OUEUE_SIZE 100

/*队列的数据类型*/
typedef int dataType;

typedef struct LQueue
{
	dataType LQueue_array[MAX_OUEUE_SIZE];//dataType类型的数组
	int front;//头指针
	int rear;//尾指针
}LQueue;
/*初始化*/
LQueue queue_init();


/*判断是否为空*/
int queue_empty(LQueue q);

/*进队*/
int queue_enter(LQueue *q, dataType e);//指针/数据元素
/*出队*/
int queue_delete(LQueue *q, dataType *e);

/*获得队头节点*/
int get_front(LQueue q, dataType *e);
/*获得队列长度*/
int get_length(LQueue q);

/*清空队列*/
void queue_clear(LQueue *q);

void visit(LQueue q);
void queue_traverse(LQueue q);






```c
#include <stdio.h>
#include<stdlib.h>
#include"LQueue.h"

LQueue queue_init()
{
	LQueue q;
	q.front = q.rear = 0;
	return q;
}
int queue_empty(LQueue q)
{
	if (q.rear==q.front)
	{
		return true;
	}
	return false;
}

int queue_enter(LQueue *q, dataType e)
{
	if (q->rear==MAX_OUEUE_SIZE||q->rear+1==q->front)//超出队列长度
	{
		return false;
	}
	q->LQueue_array[q->rear] = e;
	printf("q.LQueue_array[%d]=%d\n", q->rear, e);
	q->rear += 1;

	return true;
}
int queue_delete(LQueue *q, dataType *e) 
{
	if (queue_empty(*q))
	{
		return false;
	}
	*e = q->LQueue_array[q->front];
	//printf("q.LQueue_array[%d]=%d\n", q->front, e);
	q->front += 1;
	return true;
}
int get_front(LQueue q, dataType *e) 
{
	if (q.front==q.rear)//队空
	{
		return false
	}
	*e = q.LQueue_array[q.front];
	return true;
}

void visit(LQueue q)
{
	if (q.front==q.rear)
	{
		printf("队列为空\n");
	}
	int temp = q.front;

	while (temp!=q.rear)
	{
		printf("%d ",q.LQueue_array[temp]);
		temp += 1;
	}
	printf("\n");
}
void queue_traverse(LQueue q) 
{
	visit(q);
}
int get_length(LQueue q)
{
	int length = q.rear - q.front;
	return length;
}
void queue_clear(LQueue *q) 
{
	q->front = q->rear =0;
}



int main() 
{
	LQueue q = queue_init();
	queue_enter(&q, 1);
	/*queue_enter(&q, 2);
	queue_enter(&q, 3);
	queue_enter(&q, 4);*/
	queue_traverse(q);
	dataType *e = (dataType *)malloc(sizeof(*e));
	queue_delete(&q, e);
	printf("queue_delete(),e=%d length=%d\n", *e, get_length(q));
	//queue_traverse(q, visit);

}

在这里插入图片描述

调试的错误
printf在输出指定值的时候需要%d等,不像c#那样随意。
给指针*e开辟内存后,传指针作为实参不需要加*(,*e),只需(,e);不然到时会指向空指针
以后还要加强调试的能力,自己发现问题解决问题的感觉挺好的!
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值