两个栈实现一个队列&&两个队列实现一个栈

void EnQueue(Stack *s1, Stack *s2, int k)
{
    Push(s1, k);
}

int DeQueue(Stack *s1, Stack*s2)
{
    if(IsStackEmpty(s2) == 1)
    {
        while(IsStackEmpty(s1) == 0)
            {
                Push(s2, Pop(s1));
            }
    }
    if(IsStackEmpty(s2) == 1)
    {
        printf("Empty!\n");
    }
    return Pop(s2);


void Push(Queue *q1, Queue *q2, int k)
{
        EnQueue(q1, k);
}

int  Pop(Queue *q1, Queue *q2)
{
    int tmp;
    if(IsQueueEmpty(q1) == 1)
    {
       printf("Stack Empty!\n");
    }
    else
    {
        while(SizeOfQueue(q1) != 1)
        {
            EnQueue(q2, DeQueue(q1));
        }
        tmp = DeQueue(q1);
        while(IsQueueEmpty(q2) == 0)
        {
            EnQueue(q1, DeQueue(q2));
        }
        return tmp;
    }
}

void Push(Queue *q1, Queue *q2, int k)
{
        Queue *pushtmp;
        if(!IsQueueEmpty(q1))
        {
            pushtmp = q1;
        }
        else
        {
            pushtmp = q2;
        }
        EnQueue(pushtmp, k);
}

int  Pop(Queue *q1, Queue *q2)
{
    int tmpvalue;
    Queue *pushtmp, *tmp;
    if(!IsQueueEmpty(q1))
    {
        pushtmp = q1;
        tmp = q2;
    }
    else
    {
        pushtmp = q2;
        tmp = q1;
    }

    if(IsQueueEmpty(pushtmp))
    {
       printf("Stack Empty!\n");
    }
    else
    {
        while(SizeOfQueue(pushtmp) != 1)
        {
            EnQueue(tmp, DeQueue(pushtmp));
        }
        tmpvalue = DeQueue(pushtmp);
        return tmpvalue;
    }
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值