首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

C语言队列实现

我个人把链表、队列、栈分为一类,然后图、树分为一类。(串不考虑),分类理由就是每一类有规律可循,即你能通过修改极少数代码把链表变成队列、栈。...(这里我们不考虑其他诸如设计模式等因素),因此本贴在讲完队列之后还会归纳一下这一类数据结构规律,帮助大家更好理解数据结构 首先需要知道队列是什么,这里给一个定义:队列是只允许一段进行插入操作,一段进行删除操作线性表...,队列是先进先出结构,允许插入成为队尾,允许删除成为队头 如上图就是一个队列,这里我相信你已经对队列有了一个概念了吧,于是就可以继续看下面了 队列同样存在插入删除操作,由于我们这里讨论是链式队列实现...我们能很容易写出下面插入节点到队列代码(如果不能你就要发反思是否认真学习了): void en_queue(struct queue *q,char c){ struct node *e=new...n){ return; } e->data=c; e->next=NULL; if(q->rear==NULL){ q->front=q->rear

3.4K20
您找到你想要的搜索结果了吗?
是的
没有找到

C语言实现顺序队列

; // 队列头下标 int rear; // 队列尾下标 }*Queue; 顺序队列和顺序栈相类似,在队列顺序存储结构,除了用一组地址连续存储单元依次存放从队列头到队列元素之外...为了在C语言中描述方便起见,初始化建空队列时,令 front = rear = 0; 每当插入新队尾元素时 “尾指针增1”;每当删除队头元素时 “头指针增1”。...因此,在非空队列,头指针始终指向队列头元素,而尾指针始终指向队列尾元素下一个位置。...} return q -> front == q -> rear; } 计算顺序队列长度 /* * 求顺序队列长度(元素个数) * q 顺序队列 */ int QueueLength...用 循环队列 就可以解决假溢出情况。 源代码 源代码已上传到 GitHub Data-Structure-of-C,欢迎大家下载 C语言实现数据结构

1.6K30

C语言实现循环队列

文章目录 顺序队列假溢出 解决上溢方法 引入循环队列 循环队列判空、判满冲突 循环队列常规操作 定义循环队列结构体 初始化循环队列 循环队列判满 循环队列判空 计算循环队列长度 循环队列 入队(EnQueue...每移动一次, 队中元素都要移动 2、将队列空间设想成一个循环表,即分配给队列 m 个存储单元可以循环使用,当 rear 为 MAXSIZE 时,若队列开始端空着,又可从头使用空着空间。...引入循环队列 base[0] 接在 base[MAXSIZE -1] 之后,若 rear + 1 == M,则令 rear = 0 实现方法: 利用 模(mod,C语言中: %)运算。...解决方案: 1.另外设一个标致以区别队空、队满 2.另设一个变量,记录元素个数 3.少用一个元素空间 本文实现方法就是第三种。 ?...欢迎大家下载 C语言实现数据结构

2.9K31

链式队列(C语言实现)

链式队列(C语言实现) 链式队列存储结构: 我们知道,队列是操作受限制线性表,队列有队头和队尾,插入元素一端称为队头,删除元素一端称为队尾。...练市队列队头指针指向当前队列队头结点位置,队尾指针指向队列的当前队尾结点位置。对于不带头结点链式队列,出队列时可直接删除队头指针所指结点,因此,链式队列不带头结点更方便。...示意图(感觉图画有点垮) 头文件:LQueue.h typedef struct node//节点结构体 { DataType data; struct node *next; }LQNode...\n"); return 0; } else { *d=Q.front->data; return 1; } } //撤销动态申请存储空间 void Destroy(LQueue...list; int x; QueueInitiate(&list); for(int i=0;i<10;i++) { QueueAppend(&list,i+1); } printf("链式队列出队顺序为

46230

循环队列出队-循环队列c语言实现

一、什么是循环队列   1、基本概念   队列就是一个能够实现“先进先出”存储结构,队列分为链式队列和静态队列。...静态队列一般用数组来实现,但此时队列必须是循环队列,否则会造成巨大内存浪费;链式队列是用链表来实现队列。...b、当队列为空时,front与rear值相等,但不一定为零。   c、当队列不为空时,front指向队列第一个元素,rear指向队列最后一个元素下一个位置。   ...这个问题比较复杂,如下图所示(此图转载),假设数组存数空间为7,此时已经存放1,a,5,7,22,90六个元素了循环队列出队,如果在往数组添加一个元素,则rear=front;此时,队列满与队列判断条件...解决这个问题有两个办法:一是增加一个参数,用来记录数组当前元素个数;第二个办法是,少用一个存储空间,也就是数组最后一个存数空间不用,当(rear+1)%maxsiz=front时,队列满。

63530

栈和队列(C语言实现)

栈和队列 栈 分析 初始化与销毁栈 出栈入栈与判断栈为空 获取栈顶元素 获取栈中有效元素个数 队列 分析 初始化与销毁队列 入列,出列与判断队列是否为空 获取队列头部,尾部元素 获取队列中有效元素个数...StackEmpty(ps)); return ps->a[ps->top - 1]; } 获取栈中有效元素个数 top也就等于栈数据数量。...int StackSize(ST* ps)//获取栈中有效元素 { assert(ps); return ps->top; } 队列 分析 队列是从队头出,队尾入,数组就没有链表好用了,所以我们用单向链表...typedef struct Queue { QL* head;//头结点,指向队列队头 QL* tail;//尾结点,指向队列队尾 int siz;//计算有多少个结点 }Qu; 初始化与销毁队列...free(cur); cur = del; } q->head = q->tail = NULL; q->siz = 0; } 入列,出列与判断队列是否为空 入列 这里需要考虑队列是否为空尾插

87000

C语言实现链表队列LinkQueue

- Node:节点 - xLinkQueue:节点控制器 -- head:总是指向队列头 -- end:总是指向队列尾 - 创建队列时,实际是创建了xLinkQueue,之后对队列操作都是通过它 -...添加节点时,创建Node,并将内容复制进它buff - 弹出队列时,将Node内容先复制出来,在free释放内存 - 不是循环队列,有待改进 - 单个节点buff最大不超过(1024*3),...如queueCreate(20, 1024*3);(不知道为什么,在我STM32F4上申请1024*4失败) util.c /** 工具包 */ #include "util.h" static..."); return 0; } } /** 从内存销毁整个队列 */ void queueDestory(xLinkQueue* queue) { uint16_t total = queue...Node *head; // 队列头节点 uint8_t length; // 记录队列长度(已使用多少个节点) uint8_t size; // 每个节点buff大小 uint16

77440

队列实现栈(C语言版本)

个人主页: :✨✨✨初阶牛✨✨✨ 强烈推荐优质专栏: C++世界(持续更新) 推荐专栏1: C语言初阶 推荐专栏2: C语言进阶 个人信条: 知行合一 前言 在做这个题目之前,应当熟悉栈和队列这两种数据结构....栈和队列都是常见数据结构,它们是基于数组或链表实现线性数据结构。...} //将除了最后一个要删除元素以外其他元素,倒数据到空队列 while(QueueSize(Notempty)>1) { //将有元素队列队头值放入空队列...(myStackFree) 代码实现: void myStackFree(MyStack* obj) { //先释放栈申请链式队列 QueueDestroy(&obj->q1);...} //将除了最后一个要删除元素以外其他元素,倒数据到空队列 while(QueueSize(Notempty)>1) { //将有元素队列队头值放入空队列

14430

LeetCode刷题(7)【栈&队列】用队列实现栈(C语言)

队列实现栈 225....用队列实现栈 - 力扣(LeetCode) (leetcode-cn.com) 目的:用队列实现栈,从先进先出——>先进后出, 1234这四个数据依次从队列1队尾进入,要让4先出,一个队列是无法实现...将123依次由队列2队尾进入到队列2,此时队列1还剩一个4,将4弹出,同理,再将12依次进入到队列1,将3弹出… 也就是说。 出数据把不为空 队列数据向为空队列中导,知道剩最后一个。...---- 队列实现——队列实现——【线性表】之队列_半生瓜のblog-CSDN博客 ---- typedef int QueueDataType; typedef struct QueueNode...element on top of the stack and returns that element. */ int myStackPop(MyStack* obj) { //谁不为空就把谁元素导到另一个队列

42610

C语言队列基本操作

本篇介绍一下编程中比较重要一个数据结构队列队列有个很显著标志,对其中数据是先进先出,如果是顺序存储结构可以说就是一个受限数组,对链式存储结构就只能说是符合先进先出规则了,这种数据结构在我们真正编程还是相当常用...实际根据需要去定制自己队列。...开始 顺序队列操作 首先我们来介绍一下顺序存储结构下队列定义和基本操作 添加适当头文件,定义一个顺序存储数据结构, 这里需要添加头文件和定义一个队列顺序数据结构 #include <stdio.h...,在顺序队列,可以从数组方式去理解,这样将会让你理解起来更简单 链式队列操作 首先我们来介绍一下顺序存储结构下队列定义和基本操作 添加适当头文件,定义一个队列链式存储数据结构, 这里需要添加头文件和定义一个队列链式存储数据结构...1); } for (i = 0; i < 10; i++) { DeleteQueue(&q, &a[i]); printf("%d\n", a[i]); } } 在链式存储结构队列同样还是相对很简单

73831

数据结构:循环队列C语言实现

生活中有很多队列影子,比如打饭排队,买火车票排队问题等,可以说与时间相关问题,一般都会涉及到队列问题;从生活,可以抽象出队列概念,队列就是一个能够实现“先进先出”存储结构。...队列分为链式队列和静态队列;静态队列一般用数组来实现,但此时队列必须是循环队列,否则会造成巨大内存浪费;链式队列是用链表来实现队列。...true; else return false; } 6.如何判断循环队列是否为满 这个问题比较复杂,假设数组存数空间为7,此时已经存放1,a,5,7,22,90六个元素了,如果在往数组添加一个元素...,则rear=front;此时,队列满与队列判断条件front=rear相同,这样的话我们就不能判断队列到底是空还是满了; 解决这个问题有两个办法:一是增加一个参数,用来记录数组当前元素个数;第二个办法是...EmptyQueue(PQUEUE Q); bool Enqueue(PQUEUE Q, int val); bool Dequeue(PQUEUE Q, int *val); #endif queue.c文件代码

54830

用栈模拟实现队列(c语言版)

前言 用"栈实现队列",力扣中一道oj题,可以帮助刚接触"栈"和"队列"新手更好理解栈和队列这两种结构....出队操作 } MyQueue; 这里是借助两个栈用于模拟队列. ①:stackpush 模拟队列入队 ②:stackpop 模拟队列出队 1.2 初始化(myQueueCreate): 该队列是由两个栈实现...步骤: 申请两个栈大小空间. 申请失败时判断一下. 对队列两个栈,一次调用他们初始化函数....(myQueuePush) 对于入队列模拟实现很简单,只需要将数据压入栈(模拟入队列:stackpush)即可. void myQueuePush(MyQueue* obj, int x) {...,由于c语言不能像c++那样直接调用库. typedef int stacktype; typedef struct stack//定义栈类型 { stacktype* data; int top

14910

c语言数据结构栈和队列代码实现

这期内容就不详细具体展开了,但该有的代码还是有的,学习数据结构重点就是要亲自把代码实现,所以如果您再自己亲自写代码过程中有什么疑问欢迎大家评论区讨论。 废话不多说直接上代码。...目录 1.栈代码实现          1.1主要功能介绍 2.队列代码实现     2.1主要功能介绍      ----                                           ...1.栈代码实现 1.1主要内容:  栈初始化、元素入栈、元素出栈、获取栈顶元素、打印栈。    ...push(S, 2); push(S, 3); pop(S); printf("%d\n", Gettop(S)); printStack(S); return 0; }       2.队列代码实现...其实队列时只能在一端插入,另一端删除线性表。

14510

C语言每日一题(40)栈实现队列

力扣232 用栈实现队列 题目描述 请你仅使用两个栈实现先入先出队列。...队列应当支持一般队列支持所有操作(push、pop、peek、empty): 实现 MyQueue 类: void push(int x) 将元素 x 推到队列末尾 int pop() 从队列开头移除并返回元素...你所使用语言也许不支持栈。你可以使用 list 或者 deque(双端队列)来模拟一个栈,只要是标准栈操作即可。...思路分析 针对队列四个功能,我们逐一讲解并进行实现 1.void push(int x) 将元素 x 推到队列末尾:关于进队,没有具体返回值,对于系统如何进行存储也没有过多要求,我们就定义一个pushst...3.int peek() 返回队列开头元素:此功能与上面的思路完全一样,但先实现此功能对于上面的出队功能会非常方便,稍后在代码里会进行讲解。

11610

你知道如何使用队列实现栈吗?(C语言

这时一道非常经典题型,因为栈和队列性质是相反队列数据是先入先出,栈数据是后入先出,那么怎样使用两个队列实现栈呢? 225....用队列实现栈 这是题目的要求,如果使用C语言实现的话,只能自己写一个队列了,这里我就不详细讲解了,具体实现思路在这: http://t.csdnimg.cn/0SiCq 代码如下: typedef...: 在实现这个栈之前我们需要有一个具体思路,栈是后进先出,队列是先进后出,那么在插入上是没有区别的,在删除上就需要将对列尾部删除,那么如何实现对列尾部删除呢?...1.栈定义 题目要求是使用两个队列实现栈,那么就直接在栈定义里面包含两个队列即可。...使用while循环来实现遍历插入和删除,结束条件为nonempty内数据为1,也就是队列尾部数据,在循环内使用QueuePush将nonempty头部数据插入到empty,每次插入之后要删除掉原节点

6710
领券