纯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 ...
随机推荐
- SpringBoot(五) SpringBoot整合mybatis
一:项目结构: 二:pom文件如下: <parent> <groupId>org.springframework.boot</groupId> <artifa ...
- 重新认识快速视图窗体(Quick View Form)
关注本人微信和易信公众号: 微软动态CRM专家罗勇 ,回复158或者20151009可方便获取本文,同时可以在第一时间得到我发布的最新的博文信息,follow me! 在我的 微软Dynamics C ...
- git本地忽略
添加本地忽略文件 git update-index --assume-unchanged 忽略的文件名 恢复本地忽略文件 git update-index --no-assume-unchanged ...
- 游戏设计模式——C++单例类
前言: 本文将探讨单例类设计模式,单例类的懒汉模式/饿汉模式,单例类的多线程安全性,最后将利用C++模板减少单例类代码量. 本文假设有一个Manager管理类,并以此为探究单例类的设计模式. 懒汉模式 ...
- Ubuntu 图形界面和终端切换
场景 在使用Ubuntu时,不小心按下了 ctrl+alt+f3,突然进入终端,好慌 解决 Ubuntu保留了纯命令行模式,按下 ctrl+alt+f2-6 可以进入纯命令行界面 之后按下 ctrl+ ...
- 6.Java基础_Java自增自减/关系/逻辑/三元运算符
/* 自增自减运算符 关系运算符 逻辑运算符 三元运算符 (同C++) */ public class OperatorDemo01 { public static void main(String[ ...
- idea之前的版本
https://www.jetbrains.com/idea/download/previous.html
- CF991C Candies
CF991C Candies 洛谷评测传送门 题目描述 After passing a test, Vasya got himself a box of nn candies. He decided ...
- Python process (进程)
进程 (process) 进程是对各种资源管理的集合,包含对各种资源的调用.内存的管理.网络接口的调用 进程要操作 CPU 必须先启动一个线程,启动一个进程的时候会自动创建一个线程,进程里的第一个线程 ...
- [PHP] laravel5.5 搭建流程
1.nginx 配置 server { listen 80; server_name laravel5-test.d.com; charset utf-8; location ...