嵌入式学习第三十二天!(队列)

2024-04-11 00:12

本文主要是介绍嵌入式学习第三十二天!(队列),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1. 队列的定义:

    队列:是只允许一端进行数据插入,而另一端进行数据删除的线性表。(先进先出FIFO),如下图所示。

    队列的应用:缓冲区,即解决高速设备和低速设备数据交互的时候,速度不匹配问题

2. 存储结构:

    1. 顺序队列:循环队列

        空队列:初始两个指针都指向a1元素,如下图的左图所示;

        队列满的条件:(rear+1) % QueueSize == front,即牺牲空间来判断是否为满队列,如下图的右图所示。

        入队时:rear指针向尾部移动,front指针则依旧指向首元素,如下图的左图所示;

        出队时:front指针向下一个元素移动,释放出队元素,尾指针不变,如下图的右图所示。

        我们把头尾相接顺序存储结构称为循环队列

        1. 循环队列的定义:
typedef int DATA_TYPE;typedef struct que
{DATA_TYPE *pbase;int front;int rear;int maxSize;
}SQE_QUE;
        2. 循环队列的创建:
SQE_QUE *Create_Sqe_Queue(int maxSize)
{SQE_QUE *psqe = malloc(sizeof(SQE_QUE));if(psqe == NULL){perror("fail to malloc");return NULL;}psqe->pbase = malloc(maxSize * sizeof(DATA_TYPE));psqe->front = 0;psqe->rear = 0;psqe->maxSize = maxSize;return psqe;
}
        3. 判断循环队列是否为空或满:
int Is_Empty_Sqe_Queue(SQE_QUE *psqe)
{if(psqe->front == psqe->rear){return 1;}return 0;
}int Is_Full_Sqe_Queue(SQE_QUE *psqe)
{if(((psqe->rear + 1) % psqe->maxSize) == psqe->front){return 1;}return 0;
}
        4. 入循环队列:
int Push_Sqe_Queue(SQE_QUE *psqe, DATA_TYPE data)
{if(Is_Full_Sqe_Queue(psqe)){fprintf(stderr, "Queue full!\n");return -1;}else{psqe->pbase[psqe->rear] = data;psqe->rear = (psqe->rear+1) % psqe->maxSize;}return 0;
}
        5. 出循环队列:
int Pop_Sqe_Queue(SQE_QUE *psqe, DATA_TYPE *data)
{if(Is_Empty_Sqe_Queue(psqe)){fprintf(stderr, "Queue Empty!\n");return -1;}else{if(data != NULL){*data = psqe->pbase[psqe->front];}psqe->front = (psqe->front+1) % psqe->maxSize;}return 0;
}
        6. 读取循环队列队头的数据:
int Find_Front_Sqe_Queue(SQE_QUE *psqe, DATA_TYPE *data)
{*data = psqe->pbase[psqe->front];return 0;
}
        7. 清空循环队列:
void Clear_Sqe_Queue(SQE_QUE *psqe)
{psqe->front = psqe->rear = 0;return;
}
        8. 销毁循环队列:
void Destory_Sqe_Queue(SQE_QUE *psqe)
{free(psqe->pbase);free(psqe);return;
}
        9. 循环队列的遍历(为了方便验证队列是否正确):
void Show_Queue(SQE_QUE *psqe)
{int i = psqe->front;while(i != psqe->rear){printf("%d ", psqe->pbase[i]);i = (i + 1) % psqe->maxSize;	}printf("\n");return;
}

    2. 链式队列:

        队列的链式存储结构,其实就是线性表的单链表,只不过它只能尾进头出而已,我们把它简称为链式队列

        1. 链式队列的定义:
typedef int DATA_TYPE;typedef struct node
{DATA_TYPE data;struct node *pnext;
}QUEUE_NODE;typedef struct list
{QUEUE_NODE *pfront;QUEUE_NODE *preal;int curlen;}QUEUE_LIST;
        2. 链式队列句柄的创建:
QUEUE_LIST *Create_Queue_List(void)
{QUEUE_LIST *plist = malloc(sizeof(QUEUE_LIST));if(plist == NULL){perror("fail to malloc");return NULL;}plist->pfront = NULL;plist->preal = NULL;plist->curlen = 0;return plist;
}
        3. 链式队列结点的创建:
QUEUE_NODE *Create_Queue_Node(DATA_TYPE data)
{QUEUE_NODE *pnode = malloc(sizeof(QUEUE_NODE));if(pnode == NULL){perror("fail to malloc");return NULL;}pnode->data = data;pnode->pnext = NULL;return pnode;
}
        4. 入队列(尾插法):
int Is_Empty_Queue(QUEUE_LIST *plist)
{return plist->pfront == NULL;
}int Push_Queue_Link(QUEUE_LIST *plist, QUEUE_NODE *pnode)
{if(plist == NULL || pnode == NULL){return -1;}if(plist->pfront == NULL){plist->pfront = pnode;plist->preal = pnode;}else{plist->preal->pnext = pnode;plist->preal = pnode;}plist->curlen++;return 0;
}
        5. 出队列(头删法):
int Pop_Queue_Link(QUEUE_LIST *plist, DATA_TYPE *data)
{if(Is_Empty_Queue(plist)){return 0;}QUEUE_NODE *ptmp = plist->pfront;if(ptmp->pnext == NULL){plist->pfront = NULL;plist->preal = NULL;if(data != NULL){*data = ptmp->data;}free(ptmp);}else{plist->pfront = ptmp->pnext;if(data !=  NULL){*data = ptmp->data;}free(ptmp);}plist->curlen--;return 0;
}
        6. 获取链式队列队头的数据:
int Get_Front_Quene(QUEUE_LIST *plist, DATA_TYPE *data)
{if(Is_Empty_Queue(plist)){return 0;}QUEUE_NODE *ptmp = plist->pfront;*data = ptmp->data;return 0;
}
        7. 清空链式队列:
void Clear_Queue(QUEUE_LIST *plist)
{QUEUE_NODE *ptmp = plist->pfront;while(plist->pfront != NULL){Pop_Queue_Link(plist, NULL);}return;
}
        8. 销毁链式队列:
void Destory_Queue(QUEUE_LIST *plist)
{Clear_Queue(plist);free(plist);return;
}
        9. 链式队列的遍历(为了方便验证队列是否正确):
void Show_Queue(QUEUE_LIST *plist)
{QUEUE_NODE *ptmp = plist->pfront;while(ptmp != NULL){printf("%d ", ptmp->data);ptmp = ptmp->pnext;}printf("\n");return;
}

这篇关于嵌入式学习第三十二天!(队列)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/892548

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

hdu1180(广搜+优先队列)

此题要求最少到达目标点T的最短时间,所以我选择了广度优先搜索,并且要用到优先队列。 另外此题注意点较多,比如说可以在某个点停留,我wa了好多两次,就是因为忽略了这一点,然后参考了大神的思想,然后经过反复修改才AC的 这是我的代码 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

零基础学习Redis(10) -- zset类型命令使用

zset是有序集合,内部除了存储元素外,还会存储一个score,存储在zset中的元素会按照score的大小升序排列,不同元素的score可以重复,score相同的元素会按照元素的字典序排列。 1. zset常用命令 1.1 zadd  zadd key [NX | XX] [GT | LT]   [CH] [INCR] score member [score member ...]

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识