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

怎么做网站的排名设计师国外网站

怎么做网站的排名,设计师国外网站,东莞做网站卓诚,免费wordpress主题推荐这里是栈的源代码:栈和队列的实现 当然,自己也可以写一个栈来用,对题目来说不影响,只要符合栈的特点就行。 题目: 请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(push、pop、pe…

 这里是栈的源代码:栈和队列的实现

当然,自己也可以写一个栈来用,对题目来说不影响,只要符合栈的特点就行。

题目:

请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(pushpoppeekempty):

实现 MyQueue 类:

  • void push(int x) 将元素 x 推到队列的末尾
  • int pop() 从队列的开头移除并返回元素
  • int peek() 返回队列开头的元素
  • boolean empty() 如果队列为空,返回 true ;否则,返回 false

题解: 

做题前需要的栈:

#include <stdio.h>
#include <stdlib.h>
#include <assert.h>
#include <stdbool.h>typedef int DataType;
typedef struct Stack
{DataType* data;int top;int capacity;
}Stack;void Init(Stack *st);
void Push(Stack* st, DataType x);
void Pop(Stack* st);
DataType GetTop(Stack* st);
bool Empty(Stack* st);
void Destroy(Stack* st);
int Size(Stack* st);void Init(Stack* st)
{assert(st);st->data = NULL;st->top = 0;st->capacity = 0;
}void Push(Stack* st, DataType x)
{assert(st);if (st->capacity == st->top){int newcapacity = (st->capacity == 0) ? 4 : st->capacity * 2;DataType* temp = (DataType*)realloc(st->data, sizeof(DataType) * newcapacity);if (temp == NULL){perror("realloc fail");exit(-1);}st->data = temp;st->capacity = newcapacity;}st->data[st->top++] = x;
}void Pop(Stack* st)
{assert(st);assert(st->top > 0);st->top--;
}DataType GetTop(Stack* st)
{assert(st);assert(st->top > 0);return st->data[st->top - 1];
}bool Empty(Stack* st)
{assert(st);return (st->top == 0);
}void Destroy(Stack* st)
{assert(st);free(st->data);st->data = NULL;st->top = st->capacity = 0;}int Size(Stack* st)
{assert(st);return st->top;
}


 

题目正题:  


​
//定义出两个栈
typedef struct 
{Stack push;Stack pop;
} MyQueue;​

//初始化队列
MyQueue* myQueueCreate() 
{MyQueue* obj = (MyQueue*)malloc(sizeof(MyQueue));Init(&obj->push);Init(&obj->pop);return obj;
}

//向队列中插入元素
void myQueuePush(MyQueue* obj, int x) 
{Push(&obj->push,x);
}

//元素出队列
int myQueuePop(MyQueue* obj) 
{int ret = myQueuePeek(obj);Pop(&obj->pop);return ret;
}

//返回队列开头的元素
int myQueuePeek(MyQueue* obj) 
{if(Empty(&obj->pop)){int size = Size(&obj->push);for(int i=0; i<size; i++){Push(&obj->pop,GetTop(&obj->push));Pop(&obj->push);}}return GetTop(&obj->pop);
}

//判断队列是否为空
bool myQueueEmpty(MyQueue* obj) 
{return Empty(&obj->pop) && Empty(&obj->push);
}

//销毁队列
void myQueueFree(MyQueue* obj) 
{free((&obj->push)->data);free((&obj->pop)->data);free(obj);
}

Lei宝啊:我的主页鸭

愿所有美好如期而遇

http://www.yayakq.cn/news/452214/

相关文章:

  • 沧州市任丘建设局网站门户网站系统建设方案
  • 做网站建设公司哪家好?保险网站建设的总体目标
  • 网站怎样做才能有点击率网站做地区定位跳转
  • 国内外基于vue框架的网站建设现状广西贵港建设集团有限公司网站
  • 政务门户网站建设信息wordpress分类模板
  • 找人做网站服务器不是自己的怎么办软件应用开发
  • 自己做海报的网站网站代码图片
  • seo怎么做整站排名wordpress调查插件
  • 哪些企业用wordpress建站如何自己做网站模版
  • 比较专业的建设网站的公司网站建设与管理综合实践
  • 响应式网站标准尺寸wordpress引导页
  • 商洛市建设工程造价管理站网站最新网页版传奇游戏
  • 图片网站收录wordpress页脚添加音乐
  • 济宁做网站大约多少钱flash网站源码免费下载
  • 南京汤山建设银行网站wordpress插件 图片
  • 天津网站排名镇江网站设计
  • 深圳出名网站建设公司wordpress静态404错误
  • 公司网站微信推广廊坊手机网站建设
  • 出名的网站制作正规公司黄页官网
  • 电商网站建设的内容网站建设与维护管理实训报告
  • 做hmtl的基本网站设计师服务平台鱼巴士
  • 定制型营销网站建设元典科技网站建设
  • 网站建设策划书案例seo是什么意思知乎
  • 郑州网站建设学校网上购物平台怎么建立
  • 深圳市做网站有哪些公司项目计划书包括几个方面
  • 网站小图标素材python语言特点是什么
  • 注册网站应注意事项请人做网站我要提供什么需求
  • 哪个博客可以做单页网站网站点击量怎么查
  • 国字类型网站有哪些内容个人网站做app上传
  • 网站 设计百度seo关键词优化电话