纯C语言实现链队
#include <stdio.h>
#include <stdlib.h> typedef int QElemType; typedef struct QNode{
QElemType data;
struct QNode *next;
}QNode; typedef struct{
QNode *front;
QNode *rear;
}LinkQueue; LinkQueue *InitQueue(LinkQueue *Q); //初始化
LinkQueue *DestroyQueue(LinkQueue* Q);//销毁
void ClearQueue(LinkQueue *Q);//清空
int QueueEmpty(LinkQueue *Q);//判空
int QueueLength(LinkQueue *Q);//队列长度
QElemType GetHead(LinkQueue *Q);//获取队头元素
int EnQueue(LinkQueue *Q, QElemType e);//插入新元素到队尾
int DeQueue(LinkQueue *Q, QElemType *e);//删除队头元素
void QueueTraverse(LinkQueue *Q);//遍历 //初始化
LinkQueue *InitQueue(LinkQueue *Q){
Q = (LinkQueue *)malloc(sizeof(LinkQueue));
//共同指向头节点
Q->front = Q->rear = (QNode *)malloc(sizeof(QNode));
Q->front->next = NULL;
printf("初始化成功\n");
return Q;
} //销毁,返回一个空指针
LinkQueue *DestroyQueue(LinkQueue* Q){
QNode *p = Q->front->next;
QNode *r = p->next;
while(r){
free(p);
p = r;
r = p->next;
}
free(Q->front);
free(Q);
printf("销毁成功\n");
return NULL;
} //清空
void ClearQueue(LinkQueue *Q){
QNode *p = Q->front->next;
while(p){
p->data = ;
p = p->next;
}
printf("清空成功\n");
} //判空
int QueueEmpty(LinkQueue *Q){
return Q->rear==Q->front;
} //队列长度
int QueueLength(LinkQueue *Q){
int len = ;
QNode *p = Q->front->next;
while(p){
len++;
p = p->next;
}
return len;
} //获取队头元素
QElemType GetHead(LinkQueue *Q){
if(Q->front != Q->rear){
printf("队头元素是%d\n", Q->front->next->data);
return Q->front->next->data;
}else{
printf("空链队,无头元素\n");
return NULL;
}
} //插入新元素到队尾
int EnQueue(LinkQueue *Q, QElemType e){
QNode *p = (QNode *)malloc(sizeof(QNode));
p ->data = e;
p->next = NULL;
Q->rear->next = p;
Q->rear = p;
printf("元素%d插入成功\n", e);
return ;
} //删除队头元素
int DeQueue(LinkQueue *Q, QElemType *e){
if(Q->front == Q->rear){
printf("空链队,删除失败\n");
return ;
}
QNode *p = Q->front->next;
*e = p->data;
printf("%d元素出链队\n", *e);
Q->front->next = p->next;
//最后一个元素被删除,队尾指针指向头节点
if(Q->rear == p) Q->rear=Q->front;
free(p);
return ;
} //遍历
void QueueTraverse(LinkQueue *Q){
if(Q->front == Q->rear){
printf("空链队\n");
return;
}
QNode *p = Q->front->next;
while(p){
printf("%d ", p->data);
p = p->next;
}
printf("\n");
} int main()
{
LinkQueue *Q = NULL;
QElemType e = NULL; //初始化测试
Q = InitQueue(Q); // //判空测试
// if(QueueEmpty(Q)){
// printf("空链栈\n");
// }
// EnQueue(Q, 1);
// if(QueueEmpty(Q)){
// printf("空链栈\n");
// }
// DeQueue(Q, &e);
// if(QueueEmpty(Q)){
// printf("空链栈\n");
// } // //长度测试
// printf("链队长度为%d\n", QueueLength(Q));
// EnQueue(Q, 1);
// EnQueue(Q, 2);
// printf("链队长度为%d\n", QueueLength(Q));
// DeQueue(Q, &e);
// DeQueue(Q, &e);
// printf("链队长度为%d\n", QueueLength(Q)); // //遍历测试
// QueueTraverse(Q); // //获取头元素测试
// e = GetHead(Q);
// EnQueue(Q, 1);
// EnQueue(Q, 2);
// e = GetHead(Q);
// DeQueue(Q, &e);
// e = GetHead(Q); // //入队测试
// EnQueue(Q, 1);
// EnQueue(Q, 2);
// EnQueue(Q, 3);
// EnQueue(Q, 4);
// EnQueue(Q, 5);
// EnQueue(Q, 6);
// EnQueue(Q, 7);
// QueueTraverse(Q); // //出队测试
// EnQueue(Q, 1);
// EnQueue(Q, 2);
// EnQueue(Q, 3);
// EnQueue(Q, 4);
// QueueTraverse(Q);
// DeQueue(Q, &e);
// printf("测试e是否改变:%d\n",e);
// DeQueue(Q, &e);
// printf("测试e是否改变:%d\n",e);
// QueueTraverse(Q); // //清空测试
// EnQueue(Q, 1);
// EnQueue(Q, 2);
// ClearQueue(Q);
// QueueTraverse(Q); //销毁测试
EnQueue(Q, );
EnQueue(Q, );
Q = DestroyQueue(Q);
QueueTraverse(Q);
}
纯C语言实现链队的更多相关文章
- 纯C语言实现链栈
#include <stdio.h> #include <stdlib.h> typedef int ElemType; typedef struct StackNode{ E ...
- C语言实现链式队列
链式队列,简称"链队列",即使用链表实现的队列存储结构. 链式队列的实现思想同顺序队列类似,只需创建两个指针(命名为 top 和 rear)分别指向链表中队列的队头元素和队尾元素, ...
- 纯C语言INI文件解析
原地址:http://blog.csdn.net/foruok/article/details/17715969 在一个跨平台( Android .Windows.Linux )项目中配置文件用 IN ...
- 经典数独游戏+数独求解器—纯C语言实现
"心常乐数独小游戏"(下面简称"本软件")是一款windows平台下的数独游戏软件. 本软件是开源.免费软件. 本软件使用纯C语言编写,MinGW编译,NSIS ...
- 不好意思啊,我上周到今天不到10天时间,用纯C语言写了一个小站!想拍砖的就赶紧拿出来拍啊
花10天时间用C语言做了个小站 http://tieba.yunxunmi.com/index.html 简称: 云贴吧 不好意思啊,我上周到今天不到10天时间,用纯C语言写了一个小站!想拍砖的就赶紧 ...
- Javascript、C#、php、asp、python 等语言的链式操作的实现
一.什么是链式操作 把需要的下一步操作的对象通过上一步操作返回回来.使完成某些功能具有持续性. 二.链式操作优点 代码更精简优雅.链式操作能大大精简代码量,多项操作一行代码一气呵成,搞定: 链式操作应 ...
- C++实现链队类——合肥工业大学数据结构实验5:链式队列
实验5 5.1 实验目的 熟练掌握队列的顺序链式存储结构. 熟练掌握队列的有关算法设计,并在链队列上实现. 根据具体给定的需求,合理设计并实现相关结构和算法. 5.2 实验要求 5.2.1链队列实验要 ...
- geek青年的状态机,查表,纯C语言实现
geek青年的状态机,查表,纯C语言实现 1. 问题的提出.抽象 建一,不止是他,不少人跟我讨论过这种问题:怎样才干保证在需求变更.扩充的情况下.程序的主体部分不动呢? 这是一个很深刻和艰难的问题.在 ...
- FastDFS是纯C语言实现,只支持Linux,适合以中小文件为载体的在线服务,还可以冗余备份和负载均衡
一.理论基础 FastDFS比较适合以中小文件为载体的在线服务,比如跟NGINX(APACHE)配合搭建图片服务器. 分布式文件系统FastDFS FastDFS是纯C语言实现,只支持Linux.Fr ...
随机推荐
- DataGridView中实现点击单元格Cell动态添加自定义控件
场景 鼠标点击DataGridView的某个单元格时,此单元格添加一个自定义的控件,这里以 添加下拉框为例 效果 注: 博客主页: https://blog.csdn.net/badao_liuman ...
- RPA之AA
RoboticProcessAutomation(即机器人流程自动化),RPA机器人能够模仿大多数人类用户的行为, 比如可以登录应用程序,移动文件和文件夹,复制和粘贴数据,填写表单,从文档中提取结构化 ...
- SAP MM MB5L 报表里的差异金额如何调整?
SAP MM MB5L 报表里的差异金额如何调整? 5月3号,收到财务顾问提出的一个问题,说是MB5L报表里有差异. 如下查询条件, 报表结果里显示有差异, 经查,导致这个差异的原因之一是,一些物料批 ...
- layui js 常用语句语法
烂笔头: layui组件使用 注意layui的版本. 在head里需要引入css/js文件. 出现 form.verify,form.val is not a function的错误信息时,注意版本, ...
- BayaiM__ oracle函数_03_fjfl
BayaiM__ oracle函数_03_fjfl select TO_DATE(trunc(F_GXSJ),'YYYY-MONTH-DD') from fsxx_dx_log_new ...
- MySQL 同一Windows系统上安装多个数据库
Step 1:拷贝一份MySQL整个安装文件,并拷贝一份 my.ini 文件放置安装目录下,然后修改以下内容.注意 port 不能设置为默认的3306,这里我们设置为3307端口. basedir=C ...
- 安全类和远程类shell脚本
批量杀php小马脚本 find /home/hatdot/ -name "*.php" |xargs egrep "phpspy|c99sh|milw0rm|eval\( ...
- 执行DOS命令并返回结果
public static String excuteCommand(String command){ Runtime runtime = Runtime.getRuntime(); try { Pr ...
- Centos 7 自动安装系统-pxe
一.简介 PXE(Pre-boot Execution Environment,预启动执行环境)是由Intel公司开发的最新技术,工作于Client/Server的网络模式,支持工作站通过网络从远端服 ...
- 深度学习框架gpu安装方法
1.tensorflow pip install tensorflow-gpu==1.14.0,具体安装哪一个版本,可以把1.14.0随便填写一个数字,系统会提示可以有哪些版本可以安装 2.pytor ...