链队列的基本操作(带头结点,不带头结点)

news2024/11/19 11:21:03

结构体

typedef struct linknode{
	int data;
	struct linknode* next;后继指针
}linknode;
typedef struct {
	linknode* front, * rear;//队头队尾指针
}linkquene;

初始化队列(带头结点)

int initquene(linkquene* q)//初始化队列
{
	q->front = q->rear = (linknode*)malloc(sizeof(linknode));
	q->front->next =NULL;
}

队列判空

int isempty(linkquene* q)//队列判空
{
	if (q->front == q->rear)
		return true;
	else 
		return false;
}

进队操作

int enquene(linkquene* q, int x)//进队操作
{
	linknode* s = (linknode*)malloc(sizeof(lnode));
	s->data = x;
	s->next = NULL;
	q->rear->next = s;
	q->rear = s;
}

出队操作

int dequene(linkquene* q, int* x)//出队操作
{
	if (q->front == q->rear)
		return false;
	linknode* p = q->front->next;
	x = p->data;
	q->front->next = p->next;
	if (q->rear == p)
		q->rear = q->front;
	free(p);
	return true;
}

完整的测试代码

#include<stdio.h>
typedef struct linknode{
	int data;
	struct linknode* next;
}linknode;
typedef struct {
	linknode* front, * rear;
}linkquene;
int initquene(linkquene* q)//初始化队列
{
	q->front = q->rear = (linknode*)malloc(sizeof(linknode));
	q->front->next =NULL;
}
int isempty(linkquene* q)//队列判空
{
	if (q->front == q->rear)
		return true;
	else 
		return false;
}
int enquene(linkquene* q, int x)//进队操作
{
	linknode* s = (linknode*)malloc(sizeof(linknode));
	s->data = x;
	s->next = NULL;
	q->rear->next = s;
	q->rear = s;
}

int dequene(linkquene* q, int* x)//出队操作
{
	if (q->front == q->rear)
		return false;
	linknode* p = q->front->next;
	x = p->data;
	q->front->next = p->next;
	if (q->rear == p)
		q->rear = q->front;
	free(p);
	return true;
}
int main()
{
	linkquene q;
	initquene(&q);
	if (!isempty(&q)) //队列判空  
		printf("队列不为空\n");
	else
		printf("队列为空\n");
	int x = 0;
	printf("要进队的元素为:");
	scanf("%d", &x);
	if (enquene(&q, x)) //进队操作  
		printf("进队元素为%d\n", x);
	else
		printf("队列满,不能进队%d\n", x);
	if (dequene(&q, &x)) //出队操作  
		printf("出队元素为%d\n", x);
	else
		printf("队列为空,不能出队\n");
	printf("%d\n", x);
}

不带头结点初始化操作

int initquene(linkquene* q)//不带头结点的初始化队列
{
	q->front =NULL;
	q->next = NULL;
}

不带头结点队列判空

int isempty(linkquene* q)//不带头结点的队列判空
{
	if (q->front == NULL)
		return true;
	else
		return false;
}

不带头结点进队操作

int enquene(linkquene* q, int x)//不带头结点进队操作
{
	linknode* s = (linknode*)malloc(sizeof(linknode));
	s->data = x;
	s->next = NULL;
	if(q->front==NULL)//在空队列中插入元素
 {
	q->front=s;//修改队尾指针
	q->rear=s;
 }
 else
 {
	q->rear->next=s;//新结点插入到rear结点之后
 q->rear=s; //修改rear指针
	}
}

不带头结点的出队操作

int dequene(linkquene* q, int* x)//不带头结点的出队操作
{
	if (q->front == NULL)
		return false;
	linknode* p = q->front;
	x = p->data;
	q->front = p->next;
	if (q->rear == p)
 {
		q->front=NULL;
		q->rear =NULL;
	}
	free(p);
	return true;
}

不带头结点的完整测试代码

#include<stdio.h>
typedef struct linknode{
	int data;
	struct linknode* next;
}linknode;
typedef struct {
	linknode* front, * rear;
}linkquene;
int initquene(linkquene* q)//不带头结点的初始化队列
{
	q->front =NULL;
	q->rear = NULL;
}
int isempty(linkquene* q)//不带头结点的队列判空
{
	if (q->front == NULL)
		return true;
	else
		return false;
}
int enquene(linkquene* q, int x)//不带头结点进队操作
{
	linknode* s = (linknode*)malloc(sizeof(linknode));
	s->data = x;
	s->next = NULL;
	if(q->front==NULL)//在空队列中插入元素
 {
	q->front=s;//修改队尾指针
	q->rear=s;
 }
 else
 {
	q->rear->next=s;//新结点插入到rear结点之后
 q->rear=s; //修改rear指针
	}
}
int dequene(linkquene* q, int* x)//不带头结点的出队操作
{
	if (q->front == NULL)
		return false;
	linknode* p = q->front;
	x = p->data;
	q->front = p->next;
	if (q->rear == p)
 {
		q->front=NULL;
		q->rear =NULL;
	}
	free(p);
	return true;
}
int main()
{
	linkquene q;
	initquene(&q);
	if (!isempty(&q)) //队列判空  
		printf("队列不为空\n");
	else
		printf("队列为空\n");
	int x = 0;
	printf("要进队的元素为:");
	scanf("%d", &x);
	if (enquene(&q, x)) //进队操作  
		printf("进队元素为%d\n", x);
	else
		printf("队列满,不能进队%d\n", x);
	if (dequene(&q, &x)) //出队操作  
		printf("出队元素为%d\n", x);
	else
		printf("队列为空,不能出队\n");
	printf("%d\n", x);
}

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

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

相关文章

geant4创建自己的physicslist(以电磁物理为例)

1 基本概念 1.1 需要创建一个类继承 G4ModularPhysicist 每个physics都是继承 G4PhysicsConstruct Physicslist 由很多 physics组成&#xff0c;physics里面包含很多的process,也就是物理过程,光电效应就是一个process 1.2 model的概念:实现proces,一个process可以对应多个…

阿里云无影云电脑有什么用?常用使用场景说明

阿里云无影云电脑是一种易用、安全、高效的云上桌面服务&#xff0c;阿里云无影云电脑可用于高数据安全管控、高性能计算等要求的金融、设计、视频、教育等领域&#xff0c;适用于多种办公场景&#xff0c;如远程办公、多分支机构、安全OA、短期使用、专业制图等。阿里云百科来…

ES6(二)

文章目录 对象的扩展对象的展开运算符Object.is()Object.assign() 字符串的扩展includes(), startsWith(), endsWith()repeat()padStart()&#xff0c;padEnd()trimStart()&#xff0c;trimEnd() 运算符扩展指数运算符 Set方法应用 Map方法 对象的扩展 ES6 允许在大括号里面&a…

DC系列靶机5通关教程

信息收集 主机扫描 sudo arp-scan -l端口扫描 nmap -p- -A 192.168.16.172漏洞发现 浏览器访问靶机IP 在Contact找到类似提交数据的地方 点击submit&#xff0c;数字发生变化。不断刷新的话&#xff0c;数字依然会发生变化 使用bp抓包发送重发器查看数据包 再次点击发送查看…

修改了Android Studio 中的这两个面板配置后,代码写的更舒服了~

本文已同步发表于我的微信公众号&#xff0c;微信搜索 代码说 即可关注&#xff0c;欢迎与我沟通交流。 一、 增加打开文件的数量及展示方式 如图&#xff0c;默认AS中打开的文件个数是10个&#xff0c;当超过10个时&#xff0c;超过的部分会直接隐藏&#xff0c;甚至会直接把之…

TCP详解之重传机制

TCP详解之重传机制 TCP 实现可靠传输的方式之一&#xff0c;是通过序列号与确认应答。 在 TCP 中&#xff0c;当发送端的数据到达接收主机时&#xff0c;接收端主机会返回一个确认应答消息&#xff0c;表示已收到消息。 但在错综复杂的网络&#xff0c;并不一定能如上图那么顺…

Oracle SQL操作和查询

文章目录 一、SQL简介二、数据类型讲解三、创建表和约束1.表结构2. 更新表结构3.约束 四、DML语句1.INSERT2.序列号3.UPDATE4.删除语句5.多行插入 五、DQL语句1.简单查询语句1.1 知识点讲解1.2 案例讲解 2.聚合函数3.分组查询4.多表查询 一、SQL简介 SQL是结构化查询语言&…

Procmon.exe在cuckoo中的使用

背景 最近研究了下procmon.exe&#xff0c;该工具用途可大了&#xff0c;Procmon是微软出品用于监视Windows系统里程序的运行情况&#xff0c;监视内容包括该程序对注册表的读写、 对文件的读写、网络的连接、进程和线程的调用情况&#xff0c;procmon 是一款超强的系统监视软…

typescript字面量类型

typescript 字面量介绍 在TypeScript中&#xff0c;字面量是指在代码中直接使用的具体值&#xff0c;如字符串、数字、布尔值等。字面量类型是TypeScript中的一种特殊类型&#xff0c;它用于定义一组有限的值&#xff0c;并且可以在定义变量或函数时使用字面量作为具体值&…

基于Java的养老院管理系统的设计与实现(亮点:多角色、登录验证码、留言反馈)

养老院管理系统 一、前言二、我的优势2.1 自己的网站2.2 自己的小程序&#xff08;小蔡coding&#xff09;2.3 有保障的售后2.4 福利 三、开发环境与技术3.1 MySQL数据库3.2 Vue前端技术3.3 Spring Boot框架3.4 微信小程序 四、功能设计4.1 主要功能描述 五、系统实现5.1 养老院…

【基础篇】四、SpringBoot整合第三方技术

文章目录 1、SpringBoot整合Junit2、SpringBoot整合MyBatis3、SpringBoot整合MyBatisPlus4、SpringBoot整合Druid 1、SpringBoot整合Junit 步骤&#xff1a; 导入测试对应的starter测试类使用SpringBootTest修饰使用自动装配的形式添加要测试的对象 SpringBootTest class Spri…

IDEA(2023)解决运行乱码问题

&#x1f607;作者介绍&#xff1a;一个有梦想、有理想、有目标的&#xff0c;且渴望能够学有所成的追梦人。 &#x1f386;学习格言&#xff1a;不读书的人,思想就会停止。——狄德罗 ⛪️个人主页&#xff1a;进入博主主页 &#x1f5fc;专栏系列&#xff1a;无 &#x1f33c…

Nginx 相关介绍(Nginx是什么?能干嘛?)

Nginx的产生 没有听过Nginx&#xff1f;那么一定听过它的"同行"Apache吧&#xff01;Nginx同Apache一样都是一种WEB服务器&#xff0c;基于REST架构风格&#xff0c;以统一资源描述符(Uniform Resources Identifier)URI或者统一资源定位符(Uniform Resources Locator…

【算法专题突破】滑动窗口 - 串联所有单词的子串(15)

目录 1. 题目解析 2. 算法原理 3. 代码编写 写在最后&#xff1a; 1. 题目解析 题目链接&#xff1a;30. 串联所有单词的子串 - 力扣&#xff08;LeetCode&#xff09; 这道题其实也很好理解&#xff0c;看一下示例就基本知道是什么意思了&#xff0c; 主要就是找 s 里面…

day21算法

常见的七种查找算法&#xff1a; ​ 数据结构是数据存储的方式&#xff0c;算法是数据计算的方式。所以在开发中&#xff0c;算法和数据结构息息相关。今天的讲义中会涉及部分数据结构的专业名词&#xff0c;如果各位铁粉有疑惑&#xff0c;可以先看一下哥们后面录制的数据结构…

Ubuntu不能上网解决办法

问题及现象 Ubuntu的虚拟机&#xff08;18.04&#xff09;总是莫名就不能上网了。 使用ifconfig -a 查看&#xff0c;ensxx&#xff08;xx为虚拟机分配的id号&#xff09;对应的网卡有mac地址&#xff0c;但是没有分配ip地址。 Network中也没有Wired的选项。 临时解决方案 使…

深入学习 Redis Cluster - 集群缩容(全网最详细)

目录 一、集群缩容 1.1、准备环境 1.2、第一步&#xff0c;删除从节点 1.3、第二步&#xff0c;重新分配 slots 第一次分配&#xff1a;分配给 106 1365 个 slots 第二次分配&#xff1a;分配给102 1365 个 slots 此时查看集群状态&#xff0c;可以看到 110 节点不再持有…

【技术分享】NetLogon于域内提权漏洞(CVE-2020-1472)

一、漏洞介绍 CVE-2020-1472是一个Windows域控中严重的远程权限提升漏洞。攻击者在通过NetLogon&#xff08;MS-NRPC&#xff09;协议与AD域控建立安全通道时&#xff0c;可利用该漏洞将AD域控的计算机账号密码置为空&#xff0c;从而控制域控服务器。该漏洞适用于Win2008及后…

C#实现钉钉自定义机器人发送群消息帮助类

一、自定义机器人发送群消息使用场景 在企业中,针对一些关键指标内容(如每天的生产产量、每天的设备报警信息等信息),需要同时给多人分享,此时就可以将需要查看这些数据的人员都拉到一个群中,让群里的机器人将这些关键指标内容推送到群里即可【(目前已实现在钉钉群里创建…

Pytorch-CNN-Mnist

文章目录 model.pymain.py网络设置注意事项及改进运行截图 model.py import torch.nn as nn class CNN_cls(nn.Module):def __init__(self,in_dim28*28):super(CNN_cls,self).__init__()self.conv1 nn.Conv2d(1,32,1,1)self.pool1 nn.MaxPool2d(2,2)self.conv2 nn.Conv2d(3…