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

网站域名注册的相关证书证明文件网站建设凭证

网站域名注册的相关证书证明文件,网站建设凭证,网站开发进度控制计划表,网页翻译成中文怎么设置力扣232 用栈实现队列 题目描述 请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作#xff08;push、pop、peek、empty#xff09;#xff1a; 实现 MyQueue 类#xff1a; void push(int x) 将元素 x 推到队列的末尾int pop() 从队列的开头移除并…力扣232 用栈实现队列 题目描述 请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作push、pop、peek、empty 实现 MyQueue 类 void push(int x) 将元素 x 推到队列的末尾int pop() 从队列的开头移除并返回元素int peek() 返回队列开头的元素boolean empty() 如果队列为空返回 true 否则返回 false 说明 你 只能 使用标准的栈操作 —— 也就是只有 push to top, peek/pop from top, size, 和 is empty 操作是合法的。你所使用的语言也许不支持栈。你可以使用 list 或者 deque双端队列来模拟一个栈只要是标准的栈操作即可。 思路分析 针对队列的四个功能我们逐一讲解并进行实现 1.void push(int x) 将元素 x 推到队列的末尾关于进队没有具体的返回值对于系统如何进行存储也没有过多要求我们就定义一个pushst用来进队元素的栈将元素直接push即可。 2.int pop() 从队列的开头移除并返回元素这里就有讲究了出栈是将最后进入的元素返回但出队却是将最先进入的元素返回但又不能取到栈底元素所以我们需要再定义一个栈来进行出队用定义为popst出队的时候只需要将pushst里的元素全部出栈进栈到popst中再返回popst栈顶元素自然就是需要出队的元素了。 3.int peek() 返回队列开头的元素此功能与上面的思路完全一样的但先实现此功能对于上面的出队功能会非常方便稍后在代码里会进行讲解。 4.boolean empty() 如果队列为空返回 true 否则返回 false 直接判断两个栈同时为空即可。 完整代码 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 int StackEmpty(Stack* ps); // 销毁栈 void StackDestroy(Stack* ps);// 初始化栈 void StackInit(Stack* ps) {assert(ps);ps-a NULL;ps-_capacity 0;ps-_top 0; }// 入栈 void StackPush(Stack* ps, STDataType data) {assert(ps);//检查是否栈满if (ps-_top ps-_capacity){int newcapacity ps-_capacity 0 ? 4 : ps-_capacity * 2;Stack* ptr realloc(ps-a, sizeof(STDataType) * newcapacity);if (ptr NULL){perror(realloc fail);return;}ps-a ptr;ps-_capacity newcapacity;}//入栈ps-a[ps-_top] data;ps-_top; }// 出栈 void StackPop(Stack* ps) {assert(ps);assert(ps-_top 0);ps-_top--; }// 获取栈顶元素 STDataType StackTop(Stack* ps) {assert(ps);assert(ps-_top 0);return ps-a[ps-_top-1]; }// 获取栈中有效元素个数 int StackSize(Stack* ps) {assert(ps);return ps-_top; } // 检测栈是否为空如果为空返回非零结果如果不为空返回0 int StackEmpty(Stack* ps) {assert(ps);if (ps-_top 0){return 1;}else{return 0;} }// 销毁栈 void StackDestroy(Stack* ps) {assert(ps);free(ps-a);ps-_capacity 0;ps-_top 0; }//实现区typedef struct {Stack popst;Stack pushst;} MyQueue;MyQueue* myQueueCreate() {MyQueue* obj(MyQueue*)malloc(sizeof(MyQueue));StackInit(obj-popst);StackInit(obj-pushst);return obj; } void myQueuePush(MyQueue* obj, int x) {StackPush(obj-pushst,x);}int myQueuePop(MyQueue* obj) {int TopmyQueuePeek(obj);//将peek的元素放到top里面StackPop(obj-popst);return Top; }int myQueuePeek(MyQueue* obj) {if(StackEmpty(obj-popst))//只要popst为空将pushst的数据放到popst中要考虑到push和pop同时有数据的情况{while(!StackEmpty(obj-pushst)){StackPush(obj-popst,StackTop(obj-pushst));StackPop(obj-pushst); } }return StackTop(obj-popst);//返回pop栈顶元素 }bool myQueueEmpty(MyQueue* obj) {return StackEmpty(obj-pushst)StackEmpty(obj-popst); }void myQueueFree(MyQueue* obj) {StackDestroy(obj-popst);StackDestroy(obj-pushst);free(obj); }/*** Your MyQueue struct will be instantiated and called as such:* MyQueue* obj myQueueCreate();* myQueuePush(obj, x);* int param_2 myQueuePop(obj);* int param_3 myQueuePeek(obj);* bool param_4 myQueueEmpty(obj);* myQueueFree(obj); */
http://www.dnsts.com.cn/news/210520.html

相关文章:

  • 网站建设工具哪家好工商执照注册号查询网
  • 网站备案密码是什么样的弄个微信小程序多少钱
  • 微信公众号小说代理和网站结合怎么做百度站长怎么验证网站
  • 怎么注册网站啊工装公司怎么找
  • 手机网站大全艺术字体在线设计免费版
  • 音乐网站开发与需求wordpress 添加分享
  • 门户网站的分类html5 php 网站源码
  • 制作网站riverwordpress开发视频网站模板
  • 专业网站运营托管建设网站用什么语言编写
  • 网站免费诊断产品展示的手机网站
  • 网站建设接活华为手机网站建设策划方案
  • 网站授权管理系统怎么做晋江外贸网站建设
  • 长沙市网页设计公司西安seo高手
  • 聚企360做的网站邢台市招生考试院
  • 纪实摄影网站推荐查网站流量查询工具
  • 网站建设 用户管理北京电商网站开发公司哪家好
  • canvas 特效网站wordpress 评测
  • 做爰全过程免费的视频 网站做公司官网怎么做
  • 有了 ftp服务器密码 怎么改网站产品推广ppt
  • 做网站 思源字体WordPress插件错误
  • 建设银行粤通卡网站连锁餐厅vi设计公司
  • 国内做的较好的网站广州新站优化
  • 英国做电商网站有哪些岳阳建设网站的公司
  • 哪个网站可以找做中厚板的公司国际网站制作
  • 完整的网站开发做儿童网站
  • 官方网站下载手电筒互联网营销师怎么报考
  • 广州网站平台建设谷歌google play官网
  • 网站空间如何使用洛阳建设信息网站
  • 网站网络广告如何建设微信公众号免费做影视网站
  • 网站标题第一个词软件开发项目管理系统解决方案