纯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 ...
随机推荐
- centOS服务器安装mongodb
1.为服务器添加mongodb的包管理工具,这就相当于在windows中安装npm,以便能用npm安装各种依赖.添加了这个包管理工具,才能在后面对mongodb做一系列操作. touch /etc/y ...
- DDoS攻击工具
DDoS攻击工具 综合性工具 综合性工具除了可以进行DDoS攻击外,还可用于其他的用途,例如:端口扫描.安全审计.防火墙等.实际上,大部分综合性工具开发的原始目的并不是用于DDoS,而是"网 ...
- PHP代码篇(七)--PHP及MySQL已经使用过的函数
一.PHP常用函数 //数组转字符串 $str = implode(',',$device_string); //字符串转数组 $arr = explode(',',$device_string); ...
- 5-3 可视化库Seaborn-变量分析绘图
In [1]: %matplotlib inline import numpy as np import pandas as pd from scipy import stats,integrate ...
- c# 第22节 c#四大方法 静态方法、实例方法、虚方法、重新方法
本节内容: 1:静态方法和实例方法什么 2:虚方法是什么 3:重写方法 4:禁止重写方法 1:静态方法和实例方法是什么 静态方法,一般是类的常用方法,允许在不创建类的实例的情况下,直接调用. 静态方法 ...
- 爬虫之爬取豆瓣图书名字及ID
from urllib import request from bs4 import BeautifulSoup as bs #爬取豆瓣最受关注图书榜 resp = request.urlopen(' ...
- 201871010102-常龙龙《面向对象程序设计(java)》第十一周学习总结
项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这个作业的要求在哪里 https://www.cnblogs.com/nwnu-daizh/p ...
- Single-SPA 前端微服务化 动态路由多系统合并
每日优鲜供应链前端团队微前端改造 动态注册路由,然后根据路由判断加载子项目js资源.子项目webpack需要设置externals,然后用systemjs接管external的包加载 webpack ...
- slideDown()、slideUp()反复执行的问题
<ul class="main"> <li><a href="#">菜单一</a> <ul> < ...
- 【正则】day02
正则表达式的应用匹配.查找.分割.替换对于普通字符串处理函数和正则表达式字符处理函数,使用的原则:能用普通字符串处理函数处理的,就不要用正则表达式处理. 原因:普通字符串处理函数:效率高.简单.正则表 ...