队列的线性存储结构 c语言 数据结构 简单易懂 超详细~~

2023-05-16

#include<stdio.h>
#include<stdlib.h>
typedef int Elemtype;
#define maxsize 100
typedef struct queue
{//注意再用顺序结构来表示栈和队列时,不用再进行node节点的定义了
//首先我们不需要指针了,并且数据域可以放在队列中的数组里
int rear;
int front;
int nodes[maxsize];
}queue;
queue* initqueue();//队列的初始化
bool enqueue(queue*,int);//入队
bool outqueue(queue*);//出队
void getqueuefront(queue*);//取队列对头元素
bool isemptyqueue(queue*);//判断队列是否为空
bool isfullqueue(queue*);//判断队列是否已满
void traverse(queue*);//遍历栈的所有元素
void calculte(queue*);//获取栈的长度
int main(void)
{
queue q=initqueue();//初始化队列
enqueue(q, 1);//入队
enqueue(q, 2);
enqueue(q, 3);
enqueue(q, 4);
traverse(q);//遍历
calculte(q);//计算队列的元素的个数
outqueue(q);//出队
getqueuefront(q);//取得队列的首元素
traverse(q);
calculte(q);
}
queue
initqueue()
{
queue sQ = (queue)malloc(sizeof(queue));
if (!sQ)
{
printf(“分配内存空间失败\n”);
return 0;
}
else
{
sQ->front = sQ->rear = 0;
printf(“队列初始化完成\n”);
}
return sQ;
}
bool isfullqueue(queuesQ)
{
if (sQ->rear > maxsize)
{//sQ->rear指向队列的最后一个元素的下一个元素
//如果sQ->rear刚好等于maxsize,说明还可以装下数据
//大于就不可以了
return true;
}
else
{
return false;
}
}
bool enqueue(queue
sQ,int val)
{//入队和出队最好是有返回值类型的原因是,当遇到条件不满足的时候
//(队列已满,或队列为空的时候就可以return false返回程序
//而程序遇到return就会返回,就特别好
if (isfullqueue(sQ))
{//因为本程序中的队列使用线性表来实现的,自然就会有内存溢出的情况,所以在入队的时候应该首席按考虑队列是否已满
printf(“队列已满,无法入队\n”);
return false;
}
else
{
sQ->nodes[sQ->rear] = val;
sQ->rear++;
return true;
printf(“入队成功\n”);
}
}
bool isemptyqueue(queuesQ)
{
if (sQ->rear == sQ->front)
{//当队列的front和rear指向同一个位置时,队列中就没有任何一个元素,队列为空,
printf(“队列为空\n”);
return true;
}
else
{
return false;
}
}
bool outqueue(queue
sQ)
{
int val = 0;
if (isfullqueue(sQ))
{//注意队列必须是非空,才可以出队
printf(“队列为空,出栈失败\n”);
return false;
}
else
{
val = sQ->nodes[sQ->rear - 1];
sQ->rear–;
printf("%d已出队成功\n",val);
return true;
}
}
void getqueuefront(queuesQ)
{
int val = 0;
if (isemptyqueue(sQ))
{
printf(“队列为空,无法取得首元素\n”);
}
else
{//至于rear指针为什么要减1.因为rear是指向了最后一个元素的下一个位置,那么我们取最后一个元素的值,自然要取该位置减去1之后的值。
val = sQ->nodes[sQ->rear - 1];
printf(“队列首元素为%d\n”, val);
}
}
void traverse(queue
sQ)
{
int i = sQ->rear - 1;
if (isemptyqueue(sQ))
{
printf(“队列为空,无法进行遍历\n”);
}
else
{
while (i != -1)
{//为什么i!=-1作为循环结束的条件,因为i=0时,是储存了数据元素的,所以当我们遍历了0这个下标所对应的元素之后就没有元素了,那么循环就可以结束了,结束之后(即i=0之后,i再减1,那么循环结束的条件就是i!=-1)
printf("%d\t", sQ->nodes[i]);
i–;
}
//当然遍历也可以从第一个元素开始,到最后一个元素结束
}
printf(“队列的所有元素已经遍历成功\n”);
}
void calculte(queue*sQ)
{
int i = sQ->rear-1;
int count = 0;//count为计数器
while (i != -1)
//注意队列初始化为0时,0这个位置也是存储有元素的
{
count++;
i–;//注意每进行一个循环,i的值都要减1,否则会成为死循环。
}
printf(“队列的长度为%d\n”, count);
}

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

队列的线性存储结构 c语言 数据结构 简单易懂 超详细~~ 的相关文章

  • (踩坑指南)cd .ssh返回-bash: cd: .ssh:No such file or directory怎么办

    1 cd ssh返回 bash cd ssh No such file or directory怎么办 出现如下界面 有时候没必要在细节上过于拘泥 xff0c 不如直接配置秘钥 xff0c 反而一切都妥妥的了 2 如何保存退出 xff1f
  • Python数据处理工具—去除TXT文件里面相同的数据

    前言 本次分享的是一个对TXT数据进行处理的一个小工具 xff0c 功能如题 xff0c 是把TXT里面相同的数据给清洗掉是剩下唯一的一个 一 数据 随便在文件里面写了一点数据 xff0c 可以看到里面有很多重复的数据 xff0c 那么里面
  • Python进行ffmpeg推流和拉流rtsp、rtmp

    流媒体协议 xff0c 英文学名Streaming Protocol xff0c 用一句人话来解释 xff1a 流媒体协议是一种用于通过 Web 传递多媒体的协议 传统视频流协议 xff1a RTMP和RTSP xff0c 其中 RTMP
  • ROS Python 入门学习笔记--1--工作空间与功能包的创建

    上一节我们已经成功安装了ROS xff0c 并且还进行了小海龟实验的一个初步探索 xff0c 这一节主要给大家介绍一下ROS工作空间与功能包的创建 先来聊一下ROS的文件结构 xff1a 图片来源 xff1a 中国大学MOOC 在ROS当中
  • python运算符&用法的详细介绍

    目录 1 算数运算 2 比较运算符 3 成员运算符 4 逻辑运算 5 赋值运算 附 xff1a 类型转换 1 算数运算 运算符 xff1a 43 加 减 乘 除 整除 余数 幂运算 多用于整数 浮点数进行计算 43 也可用于字符串 xff0
  • 第三篇 树莓派的串口通信和语音识别模块

    目录 一 串口 xff08 UART xff09 二 wiringPi提供的串口API 三 语音识别模块 1 阅读模块代码 代码阅读工具 xff1a Souces Insight4 0安装 激活 汉化等 语音识别 xff08 口令模式 xf
  • 安装配置 JupyterLab ubuntu20.04

    目录 编辑 xff08 1 xff09 安装 xff08 2 xff09 配置 xff08 1 xff09 生成配置文件 xff08 2 xff09 生成jupyterlab的登录密码 xff08 3 xff09 修改 jupyter 的配
  • 笔记本安装双系统(win11+centos7)自己遇到坑的总结

    笔记本安装CentOS操作系统 当初在学习CentOS7的时候 就想在自己的笔记本上装一个CentOS7 装CentOS7和Windows双系统 xff0c 安装的过程中也查阅很多资料但是都不是很齐全 xff0c 我将自己安装的全过程总结出
  • 平衡树·splay

    文章目录 1 About splay2 基本操作2 1 数组是干啥的 xff1f 2 2 基本操作 3 splay3 1 rotate函数3 2 splay函数 4 更新操作4 1 插入函数4 2 删除函数 5 查询操作5 1 查询一个数的
  • 删除双系统中的Linux系统(总结以及恢复U盘原样)

    一丶如何删除双系统中的Linux系统 xff08 这里的双系统是win 43 Linux xff09 第一步 首先打开磁盘管理器 xff0c 将要删除的Linux系统的主分区右键点击删除 xff0c 删除后就可以关闭磁盘管理器 第二步 在电
  • centos7安装docker

    一丶先了解下 xff0c 什么是 Docker xff1f 为什么会有 Docker xff1f Docker 的优势 xff1f docker的组成 xff1f 1 为什么会有 Docker xff1f 我们知道一款产品从开发到上线 xf
  • python Anaconda3-下载方法

    一 Anaconda 下载方法 方法一 xff1a 官网下载 xff08 速度特别慢 xff09 下载过程没有技巧 xff0c 全程next xff0c 在路径 上有些小问题解决方法如下 下载Anaconda官网 xff1a https w
  • sinx、cscx、cosx、secx以及tanx、cotx图像详解

    今天在复习三角函数一章中对正切正割等图像感觉比较有意思 xff0c 仔细梳理了以下内容 xff1a sin xff1a sine cos xff1a cosine sec xff1a secant csc xff1a cosecant 首先
  • Debian配置ssh服务

    安装SSH xff0c 工作端口监听在192101 apt install y ssh vim etc ssh sshd config 修改port 192101 仅允许InsideCli客户端进行ssh访问 xff0c 其余所有主机的请求
  • Debian配置DHCP服务及DHCP中继

    Ispsrv服务器上 xff1a Apt install y isc dhcp server 安装完成后 修改dhcp监听网卡 Vim etc default isc dhcp server INTERFACEv4 61 39 要监听的网卡
  • Debian配置NFS文件共享服务

    apt install y nfs kernel server nfs common vim etc exports 添加一条共享文件配置 仅允许AppSrv主机访问该共享 webdata 192 168 100 100 rw sync n
  • Debian搭建Discuz论坛

    论坛服务需要在apache或nginx代理服务已经配置好的情况下搭建 搭建LAMP架构 在前面已经搭建了apache 这里直接安装php apt install y php 安装完成后重启apache systemctl restart a
  • Debian配置ISCSI

    添加一块10G硬盘 apt install y targetcli fb lvm2 使用新增加的硬盘创建卷组 xff0c 名称为iscsivg xff0c 再创建iSCSI共享逻辑卷 xff0c 逻辑卷名称为iscsistore xff0c
  • 链表有序合并C++(头插法)

    include lt stdio h gt include lt stdlib h gt 单链表的存储结构 typedef struct Node int data struct Node next Node LinkList Node L
  • [COCI2010] ZUMA

    题目链接 这道题很明显是一个 d p dp d p 问题 我们先考虑基本状态应该是 f i

随机推荐