代码拉取完成,页面将自动刷新
#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);
}
}
此处可能存在不合适展示的内容,页面不予展示。您可通过相关编辑功能自查并修改。
如您确认内容无涉及 不当用语 / 纯广告导流 / 暴力 / 低俗色情 / 侵权 / 盗版 / 虚假 / 无价值内容或违法国家有关法律法规的内容,可点击提交进行申诉,我们将尽快为您处理。