用栈实现队列(力扣第232题)

embedded/2024/11/15 6:18:25/

#define _CRT_SECURE_NO_WARNINGS 1
#include "assert.h"
#include "stdio.h"
#include "stdbool.h"
#include "stdlib.h"
#include "string.h"
#define N 10
typedef int STDataType;
int data;
//静态栈
//typedef struct Stack {
//	STDataType _a[N];
//	int _top;//栈顶元素
//}Stack;//动态栈
typedef struct ST {STDataType* _a;int _top;//栈顶元素int _capacity;//最大容量
}Stack;//初始化栈
void StackInit(Stack *pst);//入栈
void StackPush(Stack* pst, STDataType x);//出栈
void StackPop(Stack* pst);//获取栈顶元素
STDataType StackTop(Stack* pst);//获取栈的有效元素个数
int StackSize(Stack* pst);//判断栈是否为空,是返回1,非空返回0
bool StackEmpty(Stack* pst);//打印栈同时销毁
void StackPrint(Stack* pst);//销毁栈
void StackDestory(Stack* pst);//初始化栈
void StackInit(Stack* pst)
{assert(pst);pst->_a = NULL;pst->_top = 0;pst->_capacity = 0;
}
//入栈
void StackPush(Stack* pst, STDataType x)
{assert(pst);if (pst->_top == pst->_capacity){STDataType newcapacity = pst->_capacity == 0 ? 4 : (pst->_capacity * 2);STDataType* temp = (STDataType*)realloc(pst->_a, sizeof(STDataType) * newcapacity);if (temp == NULL){printf("realloc fail\n");exit(-1);}pst->_a = temp;pst->_capacity = newcapacity;}pst->_a[pst->_top] = x;pst->_top++;
}//出栈
void StackPop(Stack* pst)
{assert(pst);assert(pst->_top > 0);pst->_top--;
}//获取栈顶元素
STDataType StackTop(Stack* pst)
{assert(pst);assert(pst->_top>0);return pst->_a[pst->_top-1];
}//获取栈的有效元素个数
int StackSize(Stack* pst)
{assert(pst);return pst->_top;
}//判断栈是否为空,是返回1,非空返回0
bool StackEmpty(Stack* pst)
{assert(pst);if (pst->_top == 0)return true;elsereturn false;
}//打印栈
void StackPrint(Stack* pst)
{while (!StackEmpty(pst)){printf("%d\n", StackTop(pst));StackPop(pst);}
}//销毁栈
void StackDestory(Stack* pst)
{assert(pst);free(pst->_a);pst->_a = NULL;pst->_top = pst->_capacity = 0;
}//队列先进先出,栈先进后出
typedef struct {Stack st1;Stack st2;
} MyQueue;MyQueue* myQueueCreate() {MyQueue* pq=(MyQueue*)malloc(sizeof(MyQueue));if(pq==NULL)return NULL;StackInit(&pq->st1);StackInit(&pq->st2);return pq;
}void myQueuePush(MyQueue* obj, int x) {if(StackEmpty(&obj->st1)){StackPush(&obj->st2,x);}if(StackEmpty(&obj->st2)){StackPush(&obj->st1,x);}
}int myQueuePop(MyQueue* obj) {if(StackEmpty(&obj->st1)){while((&obj->st2)->_top!=1){StackPush(&obj->st1,StackTop(&obj->st2));StackPop(&obj->st2);}data=StackTop(&obj->st2);StackPop(&obj->st2);while((&obj->st1)->_top!=0){StackPush(&obj->st2,StackTop(&obj->st1));StackPop(&obj->st1);}return data;}else if(StackEmpty(&obj->st2)){while((&obj->st1)->_top!=1){StackPush(&obj->st2,StackTop(&obj->st1));StackPop(&obj->st1);}data=StackTop(&obj->st1);StackPop(&obj->st1);while((&obj->st2)->_top!=0){StackPush(&obj->st1,StackTop(&obj->st2));StackPop(&obj->st2);}}return data;
}int myQueuePeek(MyQueue* obj) {if(StackEmpty(&obj->st1)){while((&obj->st2)->_top!=0){StackPush(&obj->st1,StackTop(&obj->st2));StackPop(&obj->st2);}data=StackTop(&obj->st1);while((&obj->st1)->_top!=0){StackPush(&obj->st2,StackTop(&obj->st1));StackPop(&obj->st1);}return data;}if(StackEmpty(&obj->st2)){while((&obj->st1)->_top!=0){StackPush(&obj->st2,StackTop(&obj->st1));StackPop(&obj->st1);}data=StackTop(&obj->st2);while((&obj->st2)->_top!=0){StackPush(&obj->st1,StackTop(&obj->st2));StackPop(&obj->st2);}}return data;
}bool myQueueEmpty(MyQueue* obj) {if(StackEmpty(&obj->st1)&&StackEmpty(&obj->st2))return true;return false;
}void myQueueFree(MyQueue* obj) {StackDestory(&obj->st1);StackDestory(&obj->st2);free(obj);obj=NULL;
}/*** 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.ppmy.cn/embedded/11386.html

相关文章

AI检索增强生成引擎-RAGFlow-深度理解知识文档,提取真知灼见

💡 RAGFlow 是什么? RAGFlow是一款基于深度文档理解构建的开源RAG(Retrieval-Augmented Generation)引擎。RAGFlow个人可以为各种规模的企业及提供一套专业的RAG工作流程,结合针对用户群体的大语言模型(LL…

【JS基础知识2】你是不是也傻傻分不清节流和防抖

大家好,我是小梅 作为在前端领域不断探索的一员,最近处于待业状态。现在开始在此记录准备面试的基础知识点。如果你也遇到了相同的问题,希望本文对你有帮助。 节流和防抖的实现,相信大家基本上都是直接使用lodash库提供的方法防抖…

田忌赛马【洛谷P1650】

P1650 田忌赛马 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) #include<iostream> #include <algorithm> #include<cstdio> #include <map> using namespace std; const int N1e5100; int n; map<int,int>a,b;//映射&#xff0c;速度->数量…

数据结构——栈(C++实现)

数据结构——栈 什么是栈栈的实现顺序栈的实现链栈的实现 今天我们来看一个新的数据结构——栈。 什么是栈 栈是一种基础且重要的数据结构&#xff0c;它在计算机科学和编程中扮演着核心角色。栈的名称源于现实生活中的概念&#xff0c;如一叠书或一摞盘子&#xff0c;新添加…

flutter 点击按钮限流方案

文章目录 前言一、理解限流的思想二、flutter实现代码如下&#xff1a;总结 前言 最近写flutter项目&#xff0c;遇到提交表单重复点击问题&#xff0c;下面是解决方案&#xff0c;希望帮助到大家。 一、理解限流的思想 1、限流思想 限流&#xff08;Throttle&#xff09; 限…

面试复试基础题目-数据库相关

维护数据库的完整性&#xff0c;一致性&#xff0c;你喜欢用触发器还是自写业务逻辑&#xff1f;为什么&#xff1f; 尽可能用约束&#xff0c;比如主键、外键、唯一键、非空字段等&#xff0c;具体问题具体分析&#xff0c;数据量巨大的不要用触发器&#xff0c;小的可以用&am…

赛氪网技术支持2024年全国大学生英语竞赛 百万学子踊跃参赛

2024年全国大学生英语竞赛&#xff08;NECCS&#xff09;正如火如荼进行&#xff0c;赛氪网作为本次竞赛线上报名的唯一渠道&#xff0c;以其稳定的技术性能和卓越的技术领导力&#xff0c;为竞赛提供了强有力的技术支持。本次大赛初赛于2024年4月21日&#xff08;星期日&#…

通过使用XShell工具、Nginx环境实现服务器项目构建与发布

前言&#xff1a; 在信息化和数字化的今天&#xff0c;网站和应用的构建与发布已成为企业发展的重要一环。为了确保项目的顺利上线和稳定运行&#xff0c;选择合适的工具和环境至关重要。本文将详细介绍如何通过XShell工具以及Nginx环境来实现服务器项目的构建与发布&#xff0…