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

制作图片的免费网站淘宝商城网站建设

制作图片的免费网站,淘宝商城网站建设,珠海做网站专业公司,英国做网站的人255.用队列实现栈 不出意外大概率这几天都会更新 leetcode#xff0c;如果没有做新的题#xff0c;大概就会把 leetcode 之前写过的题整理#xff08;单链表的题目居多一点#xff09;出来写成博客 今天讲的题蛮容易出错的#xff08;注意传参啊#xff0c;最好把队列的…255.用队列实现栈 不出意外大概率这几天都会更新 leetcode如果没有做新的题大概就会把 leetcode 之前写过的题整理单链表的题目居多一点出来写成博客 今天讲的题蛮容易出错的注意传参啊最好把队列的实现写过一遍写起来就容易一点 题目 请你仅使用两个队列实现一个后入先出LIFO的栈并支持普通栈的全部四种操作push、top、pop 和 empty。 实现 MyStack 类 void push(int x) 将元素 x 压入栈顶。int pop() 移除并返回栈顶元素。int top() 返回栈顶元素。boolean empty() 如果栈是空的返回 true 否则返回 false 。 题目链接 力扣LeetCode官网 - 全球极客挚爱的技术成长平台 文字 和 画图 分析 首先思考一下 栈 和 队列 两者之间 的区别 栈先进后出用数组实现 队列先进先出用链表实现 栈 队列       2. 最大的问题就是 出元素     明显一个队列我们不好模拟出栈这里我们就要借助 两个队列去实现 栈是出 存进去的最后一个元素而队列是出 存进去的第 一 个元素要想两者对等即第一个元素也就是最后 一个元素 我们把存放所有元素的那一个队列除了最后一个元素 其它的元素都移到没有存放元素的那一个队列这样就做 到第一个元素也就是最后一个元素       3. 存入元素 这里我们需要确保其中一个队列始终为空有利于后面的 出元素另一个队列专门存入元素由于后续的出元素 导致我们无法确保哪一个队列存元素哪一个队列为空 如果 q1存元素进行一次出元素之后它就为空了 这里我们用了一个方法再定义两个指针 nonEmpty 和 Empty用来存放 两个队列 的地址开始nonEmpty存放 q1的地址Empty存放q2的地址判断 q1是否为空如 果为空nonEmpty存放q2的地址Empty存放q1的地址 也可以用 if ,else语句直接判断 代码 typedef int QLType; typedef struct QueueNode {QLType val;struct QueueNode* next; }QN;//创建节点 typedef struct QueueList {QN* head;QN* tail;int size; }QL;//创建队列 void QNInit(QL* pphead) {pphead-head pphead-tail NULL;pphead-size 0; }//队列初始化 QLType QLTop(QL* pphead) {return pphead-head-val; }//返回列队的头节点元素 QLType QLtail(QL* pphead) {return pphead-tail-val; }//返回列队的尾节点元素 int QLSize(QL* pphead) {return pphead-size; }//返回队列里面有效元素个数 bool QLEmpty(QL* pphead) {return pphead-head NULL; }//判断队列是否为空 void QNPop(QL* pphead) {QN* cur pphead-head;pphead-head pphead-head-next;free(cur);pphead-size--; }//出队列存储的第一个元素 void QNPush(QL* pphead, QLType x) {QN* newnode (QN*)malloc(sizeof(QN));newnode-next NULL;newnode-val x;if (newnode NULL){perror(malloc);return;}if (QLEmpty(pphead)){pphead-head pphead-tail newnode;}else{pphead-tail-next newnode;pphead-tail newnode;}pphead-size; }//存入队列元素//以上都是服务队列的创建typedef struct {QL q1;QL q2; }MyStack//存放两个队列MyStack* myStackCreate() {MyStack* obj (MyStack*)malloc(sizeof(MyStack));QNInit(obj-q1);QNInit(obj-q2);return obj; } //两个队列的初始化void myStackPush(MyStack* obj, int x) {if(!QLEmpty(obj-q1)){QNPush(obj-q1, x);}else{QNPush(obj-q2, x);} }//存放元素int myStackPop(MyStack* obj) {QL *nonEmpty obj-q1;QL *Empty obj-q2;if(QLEmpty(obj-q1)){nonEmpty obj-q2;Empty obj-q1;}while(QLSize(nonEmpty) 1){QNPush(Empty, QLTop(nonEmpty));QNPop(nonEmpty);}int top QLTop(nonEmpty);QNPop(nonEmpty);return top; }//出元素int myStackTop(MyStack* obj) {if(!QLEmpty(obj-q1)){return QLtail(obj-q1);}else{return QLtail(obj-q2);} }//返回栈顶元素bool myStackEmpty(MyStack* obj) {return QLEmpty(obj-q1) QLEmpty(obj-q2); }//判断两个栈是否都为空void myStackFree(MyStack* obj) {free(obj); }//销毁空间
http://www.hkea.cn/news/14451657/

相关文章:

  • 男女激烈做羞羞事网站网站韩剧58网站一起做网店
  • 做网站完整过程微信外链网站
  • 哪个网站设计素材多wordpress能不能做管理系统
  • jsp网站建设课程设计开发人员选项
  • 南宁seo品牌费用是多少广州网站优化渠道
  • 建设公司网站费用多少深圳网站建设公司模板
  • 网站logo替换wordpress 主题 积分
  • wordpress图片大小设置东莞网站优化方法
  • 男的做那个视频网站成都蓉城最新消息
  • 小白怎么做网站搬家教程赤峰做网站公司
  • 做吃穿住行网站南宁网站建设哪
  • 追波设计网站科技网站首页设计
  • 做房地产网站广告销售东莞有哪些互联网公司
  • 外贸假发 网站app拉新推广项目
  • 用公司的信息做网站违法吗网站建设行业政策
  • 晋中推广型网站开发做网站一般用什么软件
  • 土巴兔网站开发技术wordpress文章上的图片显示不出来
  • 软件外包产业是什么360优化大师官方下载
  • 陆丰网站建设创建站怎么上传网站怎么办
  • 宁波百度网站建设免费网站建设免代码
  • 深圳网站建设信科便宜深圳校园网站建设
  • 织梦大气企业网站模板(扁平化风格)竞价sem托管公司
  • 上饶公司网站建设企业形象设计教案
  • 沈阳h5建站现在去兰州会不会被隔离
  • 网站企业备案需要哪些红色旅游网页设计
  • 行业网站建设收费明细外贸业务员怎么开发客户
  • c 网站开发案例源码wordpress手机号码登录插件
  • 电子商务网站建设定位设想wordpress播客插件
  • 网站标题 逗号wordpress迁移数据库
  • 网站建设学生选课系统百度指数的搜索指数代表什么