链式队列的实现(头文件及源程序)

链式队列的实现(头文件及源程序)

Linkedqueue.h

#ifndef __LINKEDQUEUE_H__
#define __LINKEDQUEUE_H__//元素类型定义
typedef int ElemType_Queue;//结点结构体类型定义
typedef struct Node_Queue
{ElemType_Queue data;struct Node_Queue *next;}Node_Queue;//链表类型定义
typedef struct Linkedqueue
{int num;Node_Queue *rear;Node_Queue *front;
}Linkedqueue;//链表初始化
Linkedqueue *Init_Linkedqueue();//创建一个新结点
Node_Queue *Create_New_Node_Queue(ElemType_Queue value);//入队
void push_Queue(Linkedqueue *linkedqueue, ElemType_Queue value);//出队
void pop_Queue(Linkedqueue *linkedqueue);//获取队头
ElemType_Queue get_QueueHead(Linkedqueue *linkedqueue);//判断是否空队
int empty_Queue(Linkedqueue *linkedqueue);//销毁一个队列
//ForwardListHead *destroy_ForwardListHead(ForwardListHead *forwardlisthead);void destroy_Queue(Linkedqueue *linkedqueue);//获取队列长度
int length_Queue(Linkedqueue *linkedqueue);#endif

Linkedqueue.c

#include <stdio.h>
#include <stdlib.h>
#include "linkedqueue.h"//队列初始化
Linkedqueue *Init_Linkedqueue()
{Linkedqueue *linkedqueue = malloc(sizeof(Linkedqueue));linkedqueue->num = 0;linkedqueue->rear = NULL;linkedqueue->front = NULL;return linkedqueue;
}//创建一个新结点
Node_Queue *Create_New_Node_Queue(ElemType_Queue value)
{Node_Queue *new_node = malloc(sizeof(Node_Queue));new_node->data = value;new_node->next = NULL;return new_node;
}//入队
void push_Queue(Linkedqueue *linkedqueue, ElemType_Queue value)
{if (linkedqueue == NULL){printf("队列不存在!\n");return;}Node_Queue *new_node = Create_New_Node_Queue(value);if (linkedqueue->num == 0){linkedqueue->rear = new_node;linkedqueue->front = new_node;}else{linkedqueue->rear->next = new_node;linkedqueue->rear = new_node;}linkedqueue->num++;
}//出队
void pop_Queue(Linkedqueue *linkedqueue)
{if (linkedqueue == NULL){printf("队列不存在!\n");return;}Node_Queue *p = linkedqueue->front;linkedqueue->front = p->next;free(p);// p->next = NULL;linkedqueue->num--;
}//销毁一个队列
void destroy_Queue(Linkedqueue *linkedqueue)
{if (linkedqueue == NULL){printf("队列不存在!\n");return;}else{while (linkedqueue->num != 0){pop_Queue(linkedqueue);}//free(linkedqueue);linkedqueue = NULL;}
}//获取队头
ElemType_Queue get_QueueHead(Linkedqueue *linkedqueue)
{if (linkedqueue == NULL){printf("队列不存在!\n");return -1;}if (linkedqueue->num == 0){printf("队已空,获取队头元素失败!");return 0;}else{return linkedqueue->front->data;}
}//获取队列长度
int length_Queue(Linkedqueue *linkedqueue)
{if (linkedqueue == NULL){printf("队列不存在!\n");return 0;}return linkedqueue->num;
}//判断是否空队
int empty_Queue(Linkedqueue *linkedqueue)
{if (linkedqueue == NULL){return -1;//队列不存在}if (linkedqueue->num == 0){return 1;	//队空}else{return 0;	//队非空}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/264155.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

单点登录的实现

单点登录的实现 token验证&#xff1a;https://blog.csdn.net/sleepwalker_1992/article/details/82974703转载于:https://www.cnblogs.com/yishenweilv/p/10764653.html

c++ 箭头符号怎么打_焊接图纸符号标注图解示例,焊接符号标注实例及方法

基本坡口符号坡口符号(注&#xff1a;图中“破”应为“坡”)焊接图纸符号标注图解示例焊接符号标注实例及方法在焊接结构图样上&#xff0c;焊接方法可按国家标准GB5185-85的规定用阿拉伯效字表示&#xff0c;标注在指引线的尾部。常用焊接方法代号见表3-9所示。如果是组合焊接…

Tekson的数据结构程序9——搜索

9. 搜索 搜索方法有&#xff1a;顺序搜索法&#xff08;即链表搜索法&#xff09;、二分搜索法、二叉树搜索法、哈希表搜索法、TRIE树搜索法。 其中&#xff0c;链表搜索法的搜索速度为&#xff1b;二分搜索法与二叉树搜索法的搜索速度为&#xff1b;哈希表的搜索速度为&#x…

演示: GTS流量×××和CAR流量监管的效果及相关实践计划

演示&#xff1a; GTS流量和CAR流量监管的效果及相关实践计划演示目标&#xff1a;1 理解clock rate(时钟频率)和bandwidth&#xff08;带宽&#xff09;与接入速率的关系2 在模拟运营商的接入路由器ISP上配置CAR监管用户流量到认购速率64K3 取证模拟的企业网络以128K的接入速率…

给所有的交叉编译工具创建软链接

给所有的交叉编译工具创建软链接 #!/bin/bash #给所有的交叉编译工具创建软链接echo "正在给所有的交叉编译工具创建软链接..." filenamsls arm-linux-gnueabi-* #获取当前文件夹下的所有以arm-linux-gnueabi-文件名开头的文件名 cont0 #记录软链接完成个数…

写在前面

硕士毕业在即&#xff0c;我的纯CV之路即将开始&#xff0c;老师提到了潜在的研究方向&#xff0c;一个全新的领域&#xff0c;可以说是新的起点。未来四年&#xff0c;我要想不碌碌而为&#xff0c;不像硕士期间一样“泛泛而学”&#xff0c;我必须从理论到实践都做好非常扎实…

httpclient封装获取响应实体_Httpclient 接口自动化

好久木写啦&#xff01;&#xff01;&#xff01;好久木写啦&#xff01;&#xff01;&#xff01;心血来潮分享点小白的东西&#xff01;&#xff01;&#xff01;废话少说直接干货&#xff01;&#xff01;&#xff01;本文核心是将如何从数据驱动开始&#xff0c;以报告结尾…

服务器控件开发之基本概念

利用ASP.NET 2.0技术&#xff0c;创建Web自定义服务器控件并不是一件轻松的事情。因为&#xff0c;这需要开发人员了解并能够灵活应用多种Web开发技术&#xff0c;例如&#xff0c;CSS样式表、客户端脚本语言、.NET开发语言、服务器控件开发技术&#xff0c;甚至是当前最火的AJ…

如何在Django模板中注入全局变量

我们在做一些网站项目的时候&#xff0c;可能会遇到需要把某个全局变量注入到所有页面的情况&#xff0c;比如我们做一个在线商城&#xff0c;那么可能需要将用户的资料&#xff1a;比如用户的账号、用户的姓名等注入到每个页面里面。但是如果用常规的方法&#xff0c;也就是在…

JavaScript 定时器

setInterval 每隔time时间后执行内部代码&#xff0c;后边改的time时间并不起作用 var time 2000; var obj setInterval(() > {}, time);//obj 返回的是一个数字&#xff0c;作为唯一标识time200; //不起作用clearInterval(obj) //清除计时器setInterval("console.…

Ubuntu18.04更换为国内源

Ubuntu18.04更换为国内源 1、打开Linux终端&#xff0c;执行下列命令&#xff0c;将源文件备份&#xff0c;以防万一。 sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak2、选择下列任意一个源&#xff0c;将其复制 ​ 2.1 阿里源 deb http://mirrors.aliyun.com/…

如何关闭大疆gps_如何使用djisdkforwindows从mavic 2获取gps数据?

我使用windows sdk。我正在尝试使用以下方法获取gps数据:var flightControllerHandler _djiManagerInstance.ComponentManager.GetFlightControllerHandler(ProductIndex, ComponentIndex);flightControllerHandler.AircraftLocationChanged - QuadcopterOnAircraftLocationCh…

跨线程访问控件

【转帖】 我们在做winform应用的时候&#xff0c;大部分情况下都会碰到使用多线程控制界面上控件信息的问题。然而我们并不能用传统方法来做这个问题&#xff0c;下面我将详细的介绍。 首先来看传统方法&#xff1a; public partial class Form1 : Form { public Fo…

解析Nginx负载均衡

摘要&#xff1a;对于一个大型网站来说&#xff0c;负载均衡是永恒的话题。随着硬件技术的迅猛发展&#xff0c;越来越多的负载均衡硬件设备涌现出来&#xff0c;如F5 BIG-IP、Citrix NetScaler、Radware等等&#xff0c;虽然可以解决问题&#xff0c;但其高昂的价格却往往令人…

基于vue+mint-ui的mobile-h5的项目说明

基于vuemint-ui的mobile-h5的项目说明转载于:https://www.cnblogs.com/ysx215/p/10768656.html

Ubuntu20.04更换为国内源

Ubuntu20.04更换为国内源 1、打开Linux终端&#xff0c;执行下列命令&#xff0c;将源文件备份&#xff0c;以防万一。 sudo cp /etc/apt/sources.list /etc/apt/sources.list.bak2、选择下列任意一个源&#xff0c;将其复制 ​ 2.1 阿里源 deb http://mirrors.aliyun.com/…

深圳办理cdn经营许可证_深圳危化品经营许可证申请流程怎么申请?办理危化学品经营许可证...

随着深圳地区慢慢的进入了产业整合和城市规划规范化的运营中&#xff0c;很多涉及到生产的公司都逐渐被有效的整合在一起了&#xff0c;而随着深圳地区越发有效的整合生产规划&#xff0c;很多地区都逐渐的在将涉及到危险化学品生产和经营的企业都进行合理的管制&#xff0c;在…

Discuz!NT 缓存设计简析 [原创]

作为一个社区类型软件&#xff0c;大并发支持和高效稳定运行永远是“硬道理”&#xff0c;而有效安全的使用缓存恰恰能起到事倍功半的效果。而.NET本身所提供的缓存机制又显得过于“单薄”&#xff0c;比如说订制不太灵活方便, 缓存对象之间层次感不强, 使用时缺乏统一的管理等…

实验七:Xen环境下cirrOS的安装配置

实验名称&#xff1a; Xen环境下cirrOS的安装配置 实验环境&#xff1a; 这里的cirrOS和实验六中的busybox的启动方式相同&#xff0c;唯一的区别就是我们使用的cirrOS镜像中&#xff0c;已经包含了根文件系统、内核文件以及ramdisk和grub程序&#xff1b; 只需要我们使用xen环…

携程SQL面试题忘大牛解答解决思路

讨论地址&#xff1a;http://bbs.csdn.net/topics/380208742