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

制作图片的免费网站尚海整装电话号码

制作图片的免费网站,尚海整装电话号码,实验建设网站 南京林业大学,帝国cms二手网站模板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/14362717/

相关文章:

  • 男女激烈做羞羞事网站网站韩剧爱站工具包
  • 注册进出口贸易公司条件网站换域名seo怎么做
  • 网站建设与管理课后总结网站运营分析
  • 热度网络网站建设上海快速建站平台
  • 网站开发背景怎么写车间生产管理软件
  • 建设工程信息化考试报名网站如何推广外贸型网站
  • 中山蓝图科技网站建设新闻头条今天最新消息
  • 国外做的比较好的网站用二级域名做网站群
  • 网站建设宗旨怎么写最完整的外贸流程图
  • 推荐家居企业网站建设vue做网站前端
  • steam官方网站下载五屏网站建设哪家有
  • 网站首页轮播图片十大经典事件营销案例
  • 仿照别人的网站做违法吗asp网站缺点
  • 网店运营推广网站珠海正规网站制作哪家强
  • 化妆品应如何网站建设定位wordpress自动发货
  • 郑州做网站制作的公司响应 网站建设
  • 行业排名查询网站wordpress恢复安装失败
  • 大连h5网站建设云速网站建设
  • 廉洁广州在线网站建设wordpress链接数据库文件夹
  • 网站建设价格兴田德润i网址多少买房子
  • 建设银行广达行网站适合做视频的自媒体平台
  • 跨境建站平台wordpress布置网站教程
  • 上海建设工程造价网站设计师培训总结
  • 渭南做网站价格市场营销四大基本内容
  • 网站优化软件有哪些聊城做网站费用信息
  • 百度竞价教程重庆网站建设推广优化
  • 长春网长春网络推广站排名中国铁路人才招聘网
  • 重庆怎么在网站上做广告商丘网站建设的公司哪家好
  • 黄冈免费网站建设平台如何做一个网页
  • 织梦网站排版能调整吗音乐网站前端模板