当前位置: 首页 > article >正文

针对考研的C语言学习(循环队列-链表版本以及2019循环队列大题)

 题目

【注】此版本严格按照数字版循环队列的写法,rear所代表的永远是空数据

图解

1.初始化部分和插入部分

2出队

3.分部代码解析

初始化

void init_cir_link_que(CirLinkQue& q)
{
	q.rear = q.front = (LinkList)malloc(sizeof(LNode));
	q.front->next = NULL;
	q.rear->next = q.front;
}

入队

bool insert_que(CirLinkQue& q, ElemType data)
{
	//此版本严格按照数组版本的结构,rear节点所代表数据永远为空
	if (q.rear->next == q.front)
	{
		//表示现有空间已满,需额外开辟空间
		LinkList pnew = (LinkList)malloc(sizeof(LNode));
		q.rear->data = data;
		q.rear->next = pnew;
		pnew->next = q.front;
		q.rear = pnew;
		return true;
	}
	//不需要额外开辟空间
	//意思就是已经有出去过的数据了,但没有断链,可重复使用
	q.rear->data = data;
	q.rear = q.rear->next;
	return true;
}

 出队

bool pop_que(CirLinkQue& q, ElemType& data)
{
	//出队
	//判空
	if (q.rear == q.front)
	{
		return false;
	}
	data = q.front->data;
	q.front->data = NULL;//可写可不写,后面新插入的数据会覆盖这些不要的数据
	q.front = q.front->next;
	return true;
}

全部可运行代码

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
typedef int ElemType;
typedef struct node {
	ElemType data;
	struct node* next;
}LNode, * LinkList;

typedef struct {
	LinkList front;
	LinkList rear;
}CirLinkQue;

void init_cir_link_que(CirLinkQue& q)
{
	q.rear = q.front = (LinkList)malloc(sizeof(LNode));
	q.front->next = NULL;
	q.rear->next = q.front;
}

bool insert_que(CirLinkQue& q, ElemType data)
{
	//此版本严格按照数组版本的结构,rear节点所代表数据永远为空
	if (q.rear->next == q.front)
	{
		//表示现有空间已满,需额外开辟空间
		LinkList pnew = (LinkList)malloc(sizeof(LNode));
		q.rear->data = data;
		q.rear->next = pnew;
		pnew->next = q.front;
		q.rear = pnew;
		return true;
	}
	//不需要额外开辟空间
	//意思就是已经有出去过的数据了,但没有断链,可重复使用
	q.rear->data = data;
	q.rear = q.rear->next;
	return true;
}

bool pop_que(CirLinkQue& q, ElemType& data)
{
	//出队
	//判空
	if (q.rear == q.front)
	{
		return false;
	}
	data = q.front->data;
	q.front->data = NULL;//可写可不写,后面新插入的数据会覆盖这些不要的数据
	q.front = q.front->next;
	return true;
}
int main()
{
	CirLinkQue q;
	ElemType data;
	init_cir_link_que(q);
	insert_que(q, 1);
	insert_que(q, 2);
	insert_que(q, 3);
	pop_que(q, data);
	insert_que(q, 4);
	/*pop_que(q, data);
	insert_que(q, 5);
	pop_que(q, data);
	pop_que(q, data) ? puts("true") : puts("false");*/
	return 0;
}

4.运行结果图

动图展示也不太清晰,若不懂的可以手动操作一下感受一下


http://www.kler.cn/a/350316.html

相关文章:

  • 探索 SolidJS:一款高速的前端框架
  • 什么样的问题适合用递归
  • kafka学习笔记4-TLS加密 —— 筑梦之路
  • vulnhub靶场【IA系列】之Tornado
  • 语音技术在播客领域的应用(2)
  • 团体程序设计天梯赛-练习集——L1-013 计算阶乘和
  • Mybatis全局配置介绍
  • Java 条件语法指南:高效编写逻辑控制代码
  • 鸿蒙OS启动流程
  • 算法搭积木:一起来拼装 LRU!!!
  • Pagehelper获取total错误
  • 谷歌-BERT-第二步:模型使用
  • 构建未来:AIGC模型版本控制的关键策略与工具
  • R语言:ERGM指数随机图模型5:统计显著性评估GOF
  • docker compose入门7—详解build命令
  • 简单谈谈 mysql 的事务两阶段提交
  • C++调试方法(Vscode)(二) ——本地调试(ROS版)
  • qt 安装提示 无法定位程序输入点 systemparametersinfofordpi于动态链接库
  • 简单概述Ton链开发路径
  • 干部任免系统:打造高效透明公正的信息化平台
  • Android14 SystemUI 启动流程(1)
  • 工作日志:vue3各种警告
  • 【Flask】Flask数据库
  • 文件信息类QFileInfo
  • 微信小程序考试系统(lw+演示+源码+运行)
  • c++实现跳表