1 Star 0 Fork 0

唐梓迅/leetcode题解

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
剑指offer09 1.47 KB
一键复制 编辑 原始数据 按行查看 历史
唐梓迅 提交于 2022-03-08 21:57 +08:00 . add 剑指offer09.
#define MAX_QUEUE 10000
typedef struct {
int *stackA;
int *stackB;
int topA;
int topB;
} CQueue;
CQueue* cQueueCreate() {
CQueue *cq;
cq = (CQueue*)malloc(sizeof(CQueue));
if(cq == NULL)
return NULL;
cq->stackA = (int*)malloc(MAX_QUEUE * sizeof(int));
if(cq->stackA == NULL)
{
free(cq);
return NULL;
}
cq->topA = -1;
cq->stackB = (int*)malloc(MAX_QUEUE * sizeof(int));
if(cq->stackB == NULL)
{
free(cq->stackA);
free(cq);
return NULL;
}
cq->topB = -1;
return cq;
}
void cQueueAppendTail(CQueue* obj, int value) {
if(obj->topA != MAX_QUEUE)
{
obj->stackA[++obj->topA] = value;
}
}
int cQueueDeleteHead(CQueue* obj) {
int topBElem = 0;
int topAElem = 0;
if(obj->topB != -1)
{
topBElem = obj->stackB[obj->topB--];
return topBElem;
}
if(obj->topB == -1 && obj->topA != -1)
{
while(obj->topA != -1)
{
topAElem = obj->stackA[obj->topA--];
obj->stackB[++obj->topB] = topAElem;
}
}
if(obj->topB != -1)
{
topBElem = obj->stackB[obj->topB--];
return topBElem;
}
return -1;
}
void cQueueFree(CQueue* obj) {
if(obj != NULL)
{
if(obj->stackA != NULL)
free(obj->stackA);
if(obj->stackB != NULL)
free(obj->stackB);
free(obj);
}
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
Java
1
https://gitee.com/Tang-CMer/leetcode-problem-solving.git
git@gitee.com:Tang-CMer/leetcode-problem-solving.git
Tang-CMer
leetcode-problem-solving
leetcode题解
master

搜索帮助