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

温州科技网站建设搜讯网站建设

温州科技网站建设,搜讯网站建设,多语言企业网站源码,竞价推广渠道文章目录 一、队列实现栈的特点分析 1、1 具体分析 1、2 整体概括 二、队列模拟实现栈代码的实现 2、1 手撕 队列 代码 queue.h queue.c 2、2 用队列模拟实现栈代码 三、总结 #x1f64b;‍♂️ 作者#xff1a;Ggggggtm #x1f64b;‍♂️ #x1f440; 专栏#xff1… 文章目录 一、队列实现栈的特点分析 1、1 具体分析 1、2 整体概括 二、队列模拟实现栈代码的实现 2、1 手撕 队列 代码 queue.h queue.c 2、2 用队列模拟实现栈代码 三、总结  ‍♂️ 作者Ggggggtm ‍♂️  专栏数据结构与算法、高频面试问题   标题用队列模拟栈   ❣️ 寄语与其忙着诉苦不如低头赶路奋路前行终将遇到一番好风景 ❣️ 我们上篇文章讲述了用两个栈实现队列 用过对上篇文章的学习后我们再去学用两个队列实现栈就变得相对来说容易了很多。本篇文章会对用两个队列实现栈进行详解希望会对你有所帮助。  一、队列实现栈的特点分析 1、1 具体分析 队列和栈在插入数据时队列是从队尾进行插入栈是从栈顶插入。但是他们的删除数据是不同的。我们知道队列的特点是先新先出 删除数据是在对头进行删除栈的特点是先进后出也就是在栈顶进行删除。   当我们用队列实现栈时最根本的也是最重要的是需要解决删除的问题。我们用队列实现栈时在队列中的删除就不是删除对头的元素了我们需要根据栈的特点进行删除也就是我们需要删除的是队尾的元素。    操作时首先我们先往队列中插入元素。注意我们插入元素时应该往不为空的队列中插入元素如果两个队列都为空我们可以随意往一个队列中插入元素。为什么要往不为空的队列中插入元素呢我们先接着往下看。我们是用队列模拟栈此时我们想要删除的是栈顶的元素也就是队尾的元素。我们需要把前size-1个元素移动到另一个空的对列中然后再删除队列中的最后一个元素也就是队尾元素。  这也是我们为什么插入元素时要往不为空的队列中插入的原因。因为我们需要一个空的队列进行来回导元素从而达到删除队尾元素的目的。这时插入操作和删除操作我们都是可以用队列去模拟实现出栈的效果了。插入和删除重复上面的操作就可以。 1、2 整体概括 通过我们上面的分析用队列模拟实现栈和用栈模拟队列的思路大同小异。我们看用队列模拟栈的整体思路 插入时往不为空的队列插入。第一次插入时两个队列都为空此时随便插入一个队列即可。删除时需要把不为空的队列中的元素前size-1个元素导入到空队列中。然后再删除剩下的一个元素。返回栈顶的元素也就是返回队尾的元素。二、队列模拟实现栈代码的实现 我们这里用c语言实现所以还要手撕一个队列的代码。当然C容器中有队列可以直接用。大家熟悉思路后可以用其它语言做一下本题OJ链接用队列实现栈 - OJ链接LeetCode。 2、1 手撕 队列 代码 queue.h typedef int QDataType;typedef struct QNode {struct QNode* next;QDataType data; }QNode;typedef struct Queue {QNode* head;QNode* tail;int size; }Queue;void QueueInit(Queue* pq); void QueueDestory(Queue* pq);void QueuePush(Queue* pq, QDataType x); void QueuePop(Queue* pq);QDataType QueueFront(Queue* pq); QDataType QueueBack(Queue* pq);bool QueueEmpty(Queue* pq); int QueueSize(Queue* pq); queue.c void QueueInit(Queue* pq) {assert(pq);pq-head pq-tail NULL;pq-size 0; } void QueueDestory(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; }void QueuePush(Queue* pq, QDataType x) {assert(pq);QNode* tmp (QNode*)malloc(sizeof(QNode));if (tmp NULL){perror(malloc failed);exit(-1);}tmp-next NULL;tmp-data x;if (pq-head pq-tail pq-head NULL){pq-head pq-tail tmp;}else{pq-tail-next tmp;pq-tail tmp;}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--; } 2、2 用队列模拟实现栈代码 typedef int QDataType;typedef struct QNode {struct QNode* next;QDataType data; }QNode;typedef struct Queue {QNode* head;QNode* tail;int size; }Queue;void QueueInit(Queue* pq); void QueueDestory(Queue* pq);void QueuePush(Queue* pq, QDataType x); void QueuePop(Queue* pq);QDataType QueueFront(Queue* pq); QDataType QueueBack(Queue* pq);bool QueueEmpty(Queue* pq); int QueueSize(Queue* pq); void QueueInit(Queue* pq) {assert(pq);pq-head pq-tail NULL;pq-size 0; } void QueueDestory(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; }void QueuePush(Queue* pq, QDataType x) {assert(pq);QNode* tmp (QNode*)malloc(sizeof(QNode));if (tmp NULL){perror(malloc failed);exit(-1);}tmp-next NULL;tmp-data x;if (pq-head pq-tail pq-head NULL){pq-head pq-tail tmp;}else{pq-tail-next tmp;pq-tail tmp;}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; } QDataType QueueBack(Queue* pq) {assert(pq);assert(!QueueEmpty(pq));return pq-tail-data; }bool QueueEmpty(Queue* pq) {assert(pq);return pq-size 0; } int QueueSize(Queue* pq) {assert(pq);return pq-size; }typedef struct {Queue q1;Queue q2; } MyStack;MyStack* myStackCreate() {MyStack* st(MyStack*)malloc(sizeof(MyStack));if(stNULL)return false;QueueInit(st-q1);QueueInit(st-q2);return st; }void myStackPush(MyStack* obj, int x) {if(QueueSize(obj-q1)!0){QueuePush(obj-q1,x);}else{QueuePush(obj-q2,x);} }int myStackPop(MyStack* obj) {Queue* tmpobj-q1;Queue* notmpobj-q2;if(QueueSize(notmp)0){tmpobj-q2;notmpobj-q1;}while(QueueSize(notmp)1){QueuePush(tmp,QueueFront(notmp));QueuePop(notmp);}QDataType resQueueFront(notmp);QueuePop(notmp);return res; }int myStackTop(MyStack* obj) {if(QueueSize(obj-q1)!0)return QueueBack(obj-q1);elsereturn QueueBack(obj-q2); }bool myStackEmpty(MyStack* obj) {return QueueEmpty(obj-q1) QueueEmpty(obj-q2); }void myStackFree(MyStack* obj) {QueueDestory(obj-q1);QueueDestory(obj-q2);free(obj); }三、总结  以上就是整个用队列模拟实现栈的整个过程主要是利用空队列删除队尾的元素。我们应该熟练掌握用队列模拟实现栈和用栈模拟实现队列两者都是面试中的高频题目。本篇文章的讲解就到这里希望以上对容对对你有所帮助感谢阅读ovo~
http://www.dnsts.com.cn/news/49817.html

相关文章:

  • 图书类网站开发的背景WordPress点击显示弹窗内容
  • 汽车租赁网站开发ks数据分析神器
  • 网站关键词怎么修改汕头网站关键词推广
  • c 写网站建设框架网页美工设计的四大原则
  • wordpress 网页存在哪里网站优化都是怎么做的
  • 模板网站如何建设优惠券领取网站开发
  • 网站开发 盈利唐山seo公司
  • 可视化 网站开发工具三明做网站
  • 班级网站模板下载佛山高端画册设计公司
  • 营销型外贸网站建设软件西安做网站优化公司报价
  • 四川网站推广优化公司网站登陆后台管理中心不能修改前台主页
  • 网站模板 阿里网络营销平台建设
  • 腾讯学生云服务器如何做网站app开发公司招聘
  • 通过网站做跳板有什么网站可以免费做图
  • 手机网站带后台源代码鹤壁网站建设兼职
  • 网站建设与制作实验报告文章类网站后台
  • 营销型网站手机端wordpress数据库加密方式
  • 天津中小企业建设网站手机做任务网站有哪些
  • 旅游网站开发毕业设计开题报告如何制作网页图片素材
  • 哪有专做飞织鞋面的网站石家庄外贸网站建设公司
  • 湘潭网站建设 地址磐石网络本机怎么放自己做的网站
  • 上海新站专家网络公司网站建设需要多少个人
  • 美术教师网站建设心得体会龙岩做网站开发大概价格
  • 网站后台编辑器不能正常显示梵克雅宝官网旗舰店
  • 有什么手机网站wordpress 文章浏览次数
  • 台州cms建站系统擅自给公司做网站有什么责任
  • 网站关键词优化快速排名食品加工设备建站方案
  • 物流网站的建设论文适合在夜晚看的电影
  • 太原做网站制作微网站 微信网站
  • 教育网站怎么做网站数据库空间增大