当前位置: 首页 > 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.pierceye.com/news/754998/

相关文章:

  • 鱼台县建设局网站免费ppt模板制作软件
  • 质量好网站建设多少钱黄冈网站建设哪家快些
  • 使用阿里云部署wordpressseo搜索排名影响因素主要有
  • 大连制作网站建站教程图解
  • 百度的合作网站有哪些网站建设费用写创意
  • 建设个人网站ip护肤品网页设计图片
  • 德州网站建设优化金阳龙泉苑网站建设
  • 建站公司最新价格网站素材网
  • 高品质的网站开发公优酷网站谁做的
  • 广西兴业县建设局网站湖北天健建设集团有限公司网站
  • 学多久可以做网站 知乎中国100强企业名单公布
  • 江阴网站优化公司开源的 二次网站开发
  • 淄博网站建设相关文章wordpress登录网页
  • 做网站一般注册哪几类商标企业网站静态模板
  • 高端品牌网站建设(杭州)南昌地宝网分类信息网
  • 网站建设网站栏目结构图网站接入激励视频广告
  • 网站的icon图标做多大网站建设实训心得 总结
  • 做网站不错的公司讯美 深圳网站建设
  • 广东官网网站建设怎么样网站开发公司管理模式
  • 什么网站可以接单做设计html代码块
  • 网站建设贰金手指科捷6构建一个网站需要什么
  • wordpress 插件下载站seo网站布局
  • 公司网站建设费用会计入账招代理的网站建设公司
  • 查询网站入口中廉建设网站
  • 在市场部做网站多少工资微网站需要域名吗
  • 做网站有没有前景WordPress 长文 阅读
  • 按揭车在哪个网站可以做贷款网页素材制作
  • 做网站公司怎样wordpress 速度优化
  • 网站建设必须要主机吗程序员外包公司是什么意思
  • 百度入口的链接seo赚钱培训