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

长沙本地烟seo推广优势

长沙本地烟,seo推广优势,淘宝网官网首页,android开发需要学什么这里是栈的源代码:栈和队列的实现 当然,自己也可以写一个栈来用,对题目来说不影响,只要符合栈的特点就行。 题目: 请你仅使用两个栈实现先入先出队列。队列应当支持一般队列支持的所有操作(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.dt0577.cn/news/25531.html

相关文章:

  • 网站建设服务案例企业网址怎么申请
  • 农行网站不出动画怎么做商品热搜词排行榜
  • 如何搭建个人网站昆明百度推广开户费用
  • 可以做网站的渠道网络推广公司服务内容
  • 企业网站如何进行定位黑帽seo是什么意思
  • 网站做图标放在手机桌面全网搜索指数
  • 网站聚合页面怎么做长沙正规seo优化公司
  • h5网站的优势中国seo关键词优化工具
  • seo关于网站搜索排名朝阳seo推广
  • 好的学习网站打广告上海seo优化培训机构
  • 公司和个人均不能备案论坛类网站电商平台运营
  • 做淘宝客没有网站怎么做怎么找关键词
  • 郑州网站建设公司排名整合营销策略
  • 制作ppt的软件电脑版免费好口碑关键词优化
  • 班级网站设计分析网站推广和优化的原因
  • 安徽 网站开发佛山seo联系方式
  • 网站建设为中心最常见企业网站公司有哪些
  • 个体户可以网站备案吗注册域名在哪里注册
  • 网站域名怎么进行实名认证seo视频教程百度云
  • 哪个网站的图片可以做素材什么是网络营销战略
  • 百度喜欢什么样的网站搜索引擎营销特点是什么
  • 如何制作可以下单的网站上海百度推广优化排名
  • 响应式网站模板下载免费徐州网站设计
  • 电商网站建设运城百度网盘搜索引擎
  • 有什么可以做兼职的网站吗如何提高百度搜索排名
  • 网站开发 项目章程十大网络推广公司排名
  • 开发网站制作如何利用网络广告进行推广
  • 影视网站搭建哪个系统好广告投放平台公司
  • 寻花问柳专注做一家男性喜欢的网站百度竞价推广方案
  • wordpress 企业站常用网站推广方法及资源