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

网站建设详细流程视频郑州网站建设公司代运营

网站建设详细流程视频,郑州网站建设公司代运营,迁安建设局官方网站,wordpress亚马逊cdn#x1f388;个人主页#xff1a;库库的里昂 #x1f390;C/C领域新星创作者 #x1f389;欢迎 #x1f44d;点赞✍评论⭐收藏✨收录专栏#xff1a;LeetCode 刷题日志#x1f91d;希望作者的文章能对你有所帮助#xff0c;有不足的地方请在评论区留言指正#xff0c;… 个人主页库库的里昂 C/C领域新星创作者 欢迎 点赞✍评论⭐收藏✨收录专栏LeetCode 刷题日志希望作者的文章能对你有所帮助有不足的地方请在评论区留言指正大家一起学习交流 目录 1.题目描述 2.解题思路代码实现 方法双栈 思路及算法 代码实现 1.题目描述 OJ链接 【leetcode 题号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 输入 [MyQueue, push, push, peek, pop, empty] [[], [1], [2], [], [], []] 输出 [null, null, null, 1, 1, false]解释 MyQueue myQueue new MyQueue(); myQueue.push(1); // queue is: [1] myQueue.push(2); // queue is: [1, 2] (leftmost is front of the queue) myQueue.peek(); // return 1 myQueue.pop(); // return 1, queue is [2] myQueue.empty(); // return false 提示 1 x 9最多调用 100 次 push、pop、peek 和 empty假设所有操作都是有效的 例如一个空的队列不会调用 pop 或者 peek 操作 进阶 你能否实现每个操作均摊时间复杂度为 O(1) 的队列换句话说执行 n 个操作的总时间复杂度为 O(n) 即使其中一个操作可能花费较长时间。 2.解题思路代码实现 方法双栈 思路及算法 将一个栈当作输入栈用于压入push传入的数据另一个栈当作输出栈用于 pop和peek操作。 每次pop或peek时若输出栈为空则将输入栈的全部数据依次弹出并压入输出栈这样输出栈从栈顶往栈底的顺序就是队列从队首往队尾的顺序。 代码实现 typedef int STDataType; typedef struct Stack {STDataType* a;int top;int capacity; }ST;void STInit(ST* pst) {assert(pst);pst-a NULL;pst-top 0;pst-capacity 0; }void STDestroy(ST* pst) {assert(pst);free(pst-a);pst-a NULL;pst-top 0;pst-capacity 0; }void STPush(ST* pst, STDataType x) {if (pst-top pst-capacity) {int newCapacity pst-capacity 0 ? 4 : pst-capacity * 2;STDataType* tmp (STDataType*)realloc(pst-a, newCapacity * sizeof(STDataType));if (tmp NULL) {perror(realloc fail);return;}pst-a tmp;pst-capacity newCapacity;}pst-a[pst-top] x;pst-top; }bool STEmpty(ST* pst) {assert(pst);return pst-top 0; }void STPop(ST* pst) {assert(pst);assert(!STEmpty(pst));pst-top--; }STDataType STTop(ST* pst) {assert(pst);assert(!STEmpty(pst));return pst-a[pst-top - 1]; }int STSize(ST* pst) {assert(pst);return pst-top; }//------以下为OJ提供-------typedef struct {ST pushst;ST popst; } MyQueue;MyQueue* myQueueCreate() {MyQueue* obj (MyQueue*)malloc(sizeof(MyQueue));if (obj NULL) {perror(malloc fail);return 0;}STInit(obj-pushst);STInit(obj-popst);return obj; }void myQueuePush(MyQueue* obj, int x) {STPush(obj-pushst, x); }int myQueuePop(MyQueue* obj) {int front myQueuePeek(obj);STPop(obj-popst);return front; }int myQueuePeek(MyQueue* obj) {if (STEmpty(obj-popst)) {while (!STEmpty(obj-pushst)) {STPush(obj-popst, STTop(obj-pushst));STPop(obj-pushst);}}return STTop(obj-popst); }bool myQueueEmpty(MyQueue* obj) {return STEmpty(obj-pushst) STEmpty(obj-popst); }void myQueueFree(MyQueue* obj) {STDestroy(obj-pushst);STDestroy(obj-popst);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); */ 复杂度分析 时间复杂度push和empty为O(1)pop和peek为均摊O(1)。对于每个元素至多入栈和出栈各两次故均摊复杂度为O(1)。空间复杂度O(n)。其中n是操作总数。对于有n次push操作的情况队列中会有n个元素故空间复杂度为O(n)。
http://www.hkea.cn/news/14534825/

相关文章:

  • 制作个人网站怎么做sem分析
  • 贵阳网站制作策划中国菲律宾铁路项目
  • 网站建设与管理的展望与未来租用服务器
  • 网站开发用户登录前 登录后可以做ppt的软件
  • 网站正在备案中模板建网站用什么语言
  • 品牌化战略的重要性关键词优化公司兴田德润优惠吗
  • 网站开发海口海外域名可以在国内访问吗
  • 酥糖的网站建设的目的是什么淘宝官网登录入口
  • 阿里巴巴国际站买家入口als冰桶挑战赛的网络营销方式
  • 石家庄市住房建设局网站网页界面设计用什么软件
  • 宠物网站的设计与实现安徽网淮南频道
  • 做网站哪里最便宜企业免费网站模板
  • 个人可以建购物网站吗seo网站优化培训怎么样
  • 加盟招商推广网站如何通过psd做网站
  • 网站备案怎么做超链接crm平台
  • 重庆做网站建设深圳工业设计展2021
  • 网站建设与运营财务报表外贸网站开发公司
  • 株洲第三方网站建设哪家好哈尔滨网站建设公司有哪些
  • 网站行销网站建设销售一个月开几个单
  • 长沙公司网站高端网站建设什么是网络营销评估主要评估哪些方面
  • 国外h5建站中国国际贸易平台
  • 网站ui 特点wordpress权限配置文件
  • 珠海网站建设建站模板网络信息
  • 公司网站要什么做营业执照名称查询系统
  • 温岭网站建设公司设计logo网站有哪些免费
  • app建设网站公司简介做购实惠网站的意义
  • 个人网站设计欣赏查企业信息的软件
  • 服装网站建设任务表怎样在电脑安装wordpress
  • 五屏网站建设价位海南建设厅网站资质查询
  • 网站承载量怎么做网站建设毕业设计个人总结