数据结构(笔试题-栈(入栈出栈)
笔试题:
实现
//利用栈s1和s2实现队列,栈的思想是“后进先出”,队列的思想是“先进先出”,可以选择把栈s1作为入队缓存,把栈s2作为出队缓存
//入队
bool enQueue(s1,s2,int x)
{
int temp; //用于存储出栈的元素的值
//1.判断栈s1是否已满,此时分为两种情况(满了 or 未满)
if (s1->top + 1 >= maxSize)
{
//说明栈s1已满,此时分为两种情况(栈s2空 or 栈s2不空)
if ( isEmpty(s2) )
{
//此时栈s2为空,所以需要把栈s1的元素依次出栈到s2中
while( ! isEmpty(s1) )
{
pop(s1,&temp); //把出栈元素暂时存储在temp中
push(s2,temp); //把变量temp中的元素入栈到s2
}
push(s1,x); //此时栈s1为空,所以可以把元素x入栈到s1
return true;
}
else
{
//此时栈s2不空,所以无法入队
return false;
}
}
else
{
//此时栈s1未满,所以可以把元素x入栈到s1中
push(s1,x);
}
return true;
}
//判断队列为空
int isQueueEmpty(s1,s2)
{
if (isEmpty(s1) && isEmpty(s2))
{
return 1;
}
else
return 0;
}
//出队
bool enQueue(s1,s2,&x)
{
int temp; //为了存储出栈的元素
//1.判断队列是否为空,此时分为两种情况(空 or 不空)
if (isQueueEmpty(s1,s2))
{
return false;
}
else
{
//说明队列不空,此时又分为两种情况(栈s2空 or 栈s2不空)
if ( !isEmpty(s2) )
{
//说明栈s2不空,则直接把元素出栈
pop(s2,&x);
}
else
{
//说明栈s2为空,此时需要把栈s1的元素依次出栈到s2中
while( ! isEmpty(s1) )
{
pop(s1,&temp); //把出栈元素暂时存储在temp中
push(s2,temp); //把变量temp中的元素入栈到s2
}
pop(s2,&x);
}
}
return true;
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)