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

wordpress标题连接符天津seo代理商

wordpress标题连接符,天津seo代理商,减粘装置,网站建设完整步骤引言 在对顺序表,链表有了充分的理解之后,现在让我们学习栈和队列!!! 【链表】 👈链表 【顺序表】👈顺序表 目录 💯栈 1.栈的概念及结构 2.栈的实现 ⭐初始化栈 ⭐入栈 ⭐…

引言

在对顺序表,链表有了充分的理解之后,现在让我们学习栈和队列!!!

【链表】    👈链表

【顺序表】👈顺序表

目录

💯栈

1.栈的概念及结构

2.栈的实现

⭐初始化栈

⭐入栈

⭐出栈

⭐获取栈顶元素

⭐获取栈中有效元素个数

⭐检测栈是否为空

⭐销毁栈

✨实现结果

💯队列

1.队列的概念及结构

2.列队的实现 

⭐初始化列队

⭐队尾入列队

⭐队尾出列队

⭐获取队列头部元素

⭐获取队列中有效元素个数

⭐检测队列是否为空 

⭐销毁列队

✨实现结果


💯栈

1.栈的概念及结构

  • 栈:一种特殊的线性表,其只允许在固定的一端进行插入和删除元素操作。进行数据插入和删除操作的一端称为栈顶,另一端称为栈底。栈中的数据元素遵守后进先出LIFO(Last In First Out)的原则。
  • 压栈:栈的插入操作叫做进栈/压栈/入栈,入数据在栈顶
  • 出栈:栈的删除操作叫做出栈。出数据也在栈顶

先进后出 (Last In First Out

让我们思考下面2道题目,加深对栈的理解: 

2.栈的实现

栈的实现一般可以使用数组或者链表实现,相对而言数组的结构实现更优一些。因为数组在尾上插入数据的代价比较小。

// 下面是定长的静态栈的结构,实际中一般不实用,所以我们主要实现下面的支持动态增长的栈
typedef int STDataType;
#define N 10
typedef struct Stack
{STDataType _a[N];int _top; // 栈顶
}Stack;
// 支持动态增长的栈
typedef int STDataType;
typedef struct Stack
{STDataType* _a;int _top; // 栈顶int _capacity; // 容量
}Stack;// 初始化栈
void StackInit(Stack* ps);// 入栈
void StackPush(Stack* ps, STDataType data);// 出栈
void StackPop(Stack* ps);// 获取栈顶元素
STDataType StackTop(Stack* ps);// 获取栈中有效元素个数
int StackSize(Stack* ps);// 检测栈是否为空,如果为空返回非零结果,如果不为空返回0
bool StackEmpty(Stack* ps);// 销毁栈
void StackDestroy(Stack* ps);
⭐初始化栈
typedef int STDateType;
typedef struct Stack
{STDateType* a;int top;int capacity;
}ST;
⭐入栈
void StackPush(ST* p, STDateType x)
{if (p->top == p->capacity){STDateType* temp = (STDateType*)realloc(p->a, p->capacity * 2*sizeof(STDateType));if (temp==NULL){printf("realloc fail\n");exit(-1);}else{p->capacity *= 2;p->a = temp;}}p->a[p->top] = x;p->top++;
}
⭐出栈
void StackPoP(ST* p)
{assert(p);assert(p->top>0);p->top--;
}
⭐获取栈顶元素
STDateType StackTop(ST* p)
{assert(p);assert(p->top > 0);return p->a[p->top - 1];
}
⭐获取栈中有效元素个数
int Size(ST* p)
{return p->top;
}
⭐检测栈是否为空

        如果为空返回非零结果,如果不为空返回0

bool StackEmpty(ST* p)
{return p->top == 0;
}
⭐销毁栈
void StackDestory(ST* p)
{assert(p);free(p->a);p->a = NULL;p->capacity = p->top = 0;
}
实现结果
int main()
{ST p;StackInit(&p);StackPush(&p, 1);StackPush(&p, 2);StackPush(&p, 3);StackPush(&p, 4);StackPush(&p, 5);StackPush(&p, 6);while (!StackEmpty(&p)){printf("%d ", StackTop(&p));StackPoP(&p);}StackDestory(&p);return 0;
}


💯队列

1.队列的概念及结构

  • 队列:只允许在一端进行插入数据操作,在另一端进行删除数据操作的特殊线性表,队列具有先进先出FIFO(First In First Out)
  • 入队列:进行插入操作的一端称为队尾
  • 出队列:进行删除操作的一端称为队头

2.列队的实现 

队列的实现方式包括数组和链表。常见的队列实现方式有:

  1. 数组实现:使用一维数组存储元素,通过头指针和尾指针分别指向队头和队尾实现入队和出队操作。
  2. 链表实现:每个元素使用一个节点存储,通过指针链接实现队列,入队操作在链表末尾插入新节点,出队操作删除链表头节点。                                  从head端删除元素,从tail端插入元素
  • 队列也可以数组和链表的结构实现,使用链表的结构实现更优一些。
  • 因为如果使用数组的结构,出队列在数组头上出数据,效率会比较低。(需要将后面的元素集体前移)
// 链式结构:表示队列
typedef struct QListNode
{struct QListNode* _pNext;QDataType _data;
}QNode;// 队列的结构
typedef struct Queue
{QNode* _front;QNode* _rear;
}Queue;// 初始化队列
void QueueInit(Queue* q);// 队尾入队列
void QueuePush(Queue* q, QDataType data);// 队头出队列
void QueuePop(Queue* q);// 获取队列头部元素
QDataType QueueFront(Queue* q);// 获取队列中有效元素个数
int QueueSize(Queue* q);// 检测队列是否为空,如果为空返回非零结果,如果非空返回0
int QueueEmpty(Queue* q);// 销毁队列
void QueueDestroy(Queue* q);
⭐初始化列队
void QueueInit(Queue* pq)
{assert(pq);pq->head = pq->tail = NULL;pq->size = 0;
}
⭐队尾入列队
void QueuePush(Queue* pq, QDatatype x)
{QNode* newnode = (QNode*)malloc(sizeof(QNode));if (newnode == NULL){perror("malloc fail");return;}newnode->data = x;newnode->next = NULL;if (pq->head == NULL){assert(pq->tail == NULL);pq->head = pq->tail = newnode;}else{pq->tail->next = newnode;pq->tail = newnode;}pq->size++;
}
⭐队尾出列队
void QueuePop(Queue* pq)
{assert(pq);assert(pq->head != NULL);if (pq->head->next == NULL){free(pq->head);pq->head = pq->tail = NULL;}else{QNode* next = pq->head->next;free(pq->head);pq->head = next;}pq->size--;
}
⭐获取队列头部元素
QDatatype QueueFront(Queue* pq)
{assert(pq);assert(!QueueEmpty(pq));return pq->head->data;
}
⭐获取队列中有效元素个数
int QueueSize(Queue* pq)
{assert(pq);return pq->size;
}
⭐检测队列是否为空 

        如果为空返回非零结果,如果不为空返回0

bool QueueEmpty(Queue* pq)
{assert(pq);return pq->size == 0;
}
⭐销毁列队
void QueueDestroy(Queue* pq)
{assert(pq);QNode* cur = pq->head;while (cur){QNode* next = cur->next;free(cur);cur = next;}pq->head = pq->tail = NULL;pq->size = 0;
}
实现结果
int main()
{Queue p;QueueInit(&p);QueuePush(&p, 1);QueuePush(&p, 2);QueuePush(&p, 3);QueuePush(&p, 4);QueuePush(&p, 5);while (!QueueEmpty(&p)){printf("%d ",QueueFront(& p));QueuePop(&p);}QueueDestory(&p);return 0;
}


                                 💝💝💝以上就是本文章的全部内容啦~💝💝💝

感谢你看到最后,点个赞再走吧!

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。✨✨ 欢迎订阅本专栏 ✨✨


文章转载自:
http://dinncomilo.ssfq.cn
http://dinncoepilithic.ssfq.cn
http://dinncobasilect.ssfq.cn
http://dinncorowover.ssfq.cn
http://dinncoausterity.ssfq.cn
http://dinnconegro.ssfq.cn
http://dinncoriancy.ssfq.cn
http://dinncodrawshave.ssfq.cn
http://dinncoazimuth.ssfq.cn
http://dinncowhipstitch.ssfq.cn
http://dinncolargess.ssfq.cn
http://dinnconecrophagia.ssfq.cn
http://dinncoclistogamy.ssfq.cn
http://dinncodipsey.ssfq.cn
http://dinncolexics.ssfq.cn
http://dinncojazzman.ssfq.cn
http://dinncoaluminothermy.ssfq.cn
http://dinncoflange.ssfq.cn
http://dinncocasuistical.ssfq.cn
http://dinncoelena.ssfq.cn
http://dinncocensure.ssfq.cn
http://dinncoimbecile.ssfq.cn
http://dinncobrickwork.ssfq.cn
http://dinncoendoscopy.ssfq.cn
http://dinncodysautonomia.ssfq.cn
http://dinncosuperpersonal.ssfq.cn
http://dinncotoxaemic.ssfq.cn
http://dinncopalermo.ssfq.cn
http://dinncoweeder.ssfq.cn
http://dinncodaubry.ssfq.cn
http://dinncounfed.ssfq.cn
http://dinncoclaustration.ssfq.cn
http://dinncothundershower.ssfq.cn
http://dinncoviviparism.ssfq.cn
http://dinncoabdominal.ssfq.cn
http://dinncosuperphosphate.ssfq.cn
http://dinncohippomaniac.ssfq.cn
http://dinncochatterbox.ssfq.cn
http://dinncojewelfish.ssfq.cn
http://dinncorecremental.ssfq.cn
http://dinncounion.ssfq.cn
http://dinncoenclave.ssfq.cn
http://dinncorewaken.ssfq.cn
http://dinncoaviculture.ssfq.cn
http://dinncoteeny.ssfq.cn
http://dinncocape.ssfq.cn
http://dinncoenvision.ssfq.cn
http://dinncoalipterion.ssfq.cn
http://dinncophilosophical.ssfq.cn
http://dinncotetramorphic.ssfq.cn
http://dinncoalbuminuria.ssfq.cn
http://dinncocutesy.ssfq.cn
http://dinncocarsey.ssfq.cn
http://dinncouniliteral.ssfq.cn
http://dinncodichroic.ssfq.cn
http://dinncocomplaisant.ssfq.cn
http://dinncoquaquaversal.ssfq.cn
http://dinncotucotuco.ssfq.cn
http://dinncoue.ssfq.cn
http://dinncoproselyte.ssfq.cn
http://dinncomember.ssfq.cn
http://dinncogearless.ssfq.cn
http://dinncoallot.ssfq.cn
http://dinncodurrie.ssfq.cn
http://dinncoyesteryear.ssfq.cn
http://dinncoadroitly.ssfq.cn
http://dinncoukrainian.ssfq.cn
http://dinncochino.ssfq.cn
http://dinncosnowslide.ssfq.cn
http://dinncographite.ssfq.cn
http://dinncocontorted.ssfq.cn
http://dinncoheartbreak.ssfq.cn
http://dinncolathi.ssfq.cn
http://dinncowashboard.ssfq.cn
http://dinncolegitimately.ssfq.cn
http://dinncoadenology.ssfq.cn
http://dinncoeigenvector.ssfq.cn
http://dinncounwisely.ssfq.cn
http://dinncopostprandial.ssfq.cn
http://dinncobeechy.ssfq.cn
http://dinncoamiss.ssfq.cn
http://dinncothomasine.ssfq.cn
http://dinncoupstand.ssfq.cn
http://dinncodictograph.ssfq.cn
http://dinncotheremin.ssfq.cn
http://dinncobasket.ssfq.cn
http://dinncoedbiz.ssfq.cn
http://dinncomunificent.ssfq.cn
http://dinncounderrepresentation.ssfq.cn
http://dinncosnippers.ssfq.cn
http://dinncocountrywoman.ssfq.cn
http://dinncokadi.ssfq.cn
http://dinncocretic.ssfq.cn
http://dinncodamnably.ssfq.cn
http://dinncoentad.ssfq.cn
http://dinncocrease.ssfq.cn
http://dinncobelievable.ssfq.cn
http://dinncohump.ssfq.cn
http://dinncoepinastic.ssfq.cn
http://dinncovolcanize.ssfq.cn
http://www.dinnco.com/news/115616.html

相关文章:

  • 自己的电脑做网站空间视屏品牌推广方案范文
  • 没有服务器怎么先做网站互联网营销师国家职业技能标准
  • 做视频的网站那几个盈利了海南百度推广开户
  • 电商供应链网站贵州seo培训
  • 网络科技公司网站源码腾讯广告推广平台入口
  • 大连网络备案做网站网络营销企业案例分析
  • 如何做授权网站申请域名
  • 网站建立企业中国楼市最新消息
  • 项目网站基础设施建设如何在百度推广自己
  • 中国住房和建设部网站seo建站营销
  • 网站制作群系统seo自然优化排名技巧
  • 网站设计开发制作利尔化学股票
  • python做个人网站最彻底的手机优化软件
  • 个人备案 网站名称 例子免费的短视频app大全
  • 动态网站课程设计百度极速版客服人工在线咨询
  • 东丰在线网站建设宁波seo关键词优化教程
  • 用thinkphp做的网站推广app的单子都在哪里接的
  • 做企业网站需要服务器么百度推广平台登录网址
  • 黄石做网站公司百度云官网首页
  • 网站怎么解析域名解析网站设计平台
  • 寒亭做网站如何做营销推广
  • 黑龙江建设网ca锁网站seo具体怎么做?
  • 网站建设seo 视频淘宝的17种免费推广方法
  • 网站升级中搜索引擎排名优化seo课后题
  • 自己做一网站 多做宣传.搜索引擎优化的主要策略
  • 合肥知名网站制作公司石家庄网络推广平台
  • 西安专业网站建设公司建网站费用
  • 做家装的网站有什么区别网络推广的渠道和方式有哪些
  • 网站建设怎么问问题深圳推广优化公司
  • 微信平台的微网站怎么做郑州seo方案