数据结构之栈和队列面试题(3)两个队列实现一个栈

本文介绍了一种使用两个队列实现栈的方法。通过保持其中一个队列为空并利用队列的先进先出特性来模拟栈的后进先出行为。文章提供了详细的入栈、出栈及取栈顶元素的操作步骤,并附上了完整的C语言代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

我们知道队列是先进先出,而栈是后进先出的,所以要拿两个队列来实现一个栈,我们思路就应该这样:
每次总保持一个队列为空,对另一个队列进行操作。
入栈操作时,我们在那个有元素的队列后面直接用入队列操作,就相当于是栈的入栈操作。
在进行出栈操作的时候,我们将有元素的队列里面的元素依次出队列,并且入队列另一个队列,当出的还剩一个元素的时候,这个时候出队列的元素就是队尾元素,就相当于栈的出栈。正好就是栈的后入先出。

下面就是具体的代码实现

#include <stdio.h>
#include "seqqueue.h"
#include"seqqueue.c"
typedef struct stackqueue{
    seqqueue queue1;
    seqqueue queue2;
}stackqueue;

初始化函数

void stackqueue_init(stackqueue *s)
{
    if(s == NULL)
    {
        return;
    }
    seqqueue_init(&s->queue1);
    seqqueue_init(&s->queue2);
    return;
}

打印函数

void stackqueue_print(stackqueue *s)
{
    if(s == NULL)
    {
        return;
    }
    size_t i = 0;
    if(s->queue1.size == 0)
    {
        for(i = s->queue2.head;i < s->queue2.tail;i++)
        {
            if(i > MAXSIZE)
            {
                i = 0;
            }
            printf("[%c] ",s->queue2.data[i]);
            printf("\n");
            return;
        }
    }
    if(s->queue2.size == 0)
    {
        for(i = s->queue1.head;i < s->queue1.tail;i++)
        {
            if(i > MAXSIZE)
            {
                i = 0;
            }
            printf("[%c] ",s->queue1.data[i]);
            printf("\n");
        }
    }
}

入栈函数

void stackqueue_push(stackqueue *s,seqqueuetype value)
{
    if(s == NULL)
    {
        return;
    }
    if(s->queue1.size == 0)
    {
        seqqueue_push(&s->queue2,value);
    }
    if(s->queue2.size == 0)
    {
        seqqueue_push(&s->queue1,value);
    }
}

出栈函数

void stackqueue_pop(stackqueue *s)
{
    if(s == NULL)
    {
        return;
    }
    seqqueuetype top;
    if(s->queue1.size != 0)
    {
        while(1)
        {
            if(s->queue1.size == 1)
            {
                seqqueue_pop(&s->queue1);
                return;
            }
            seqqueue_gettop(&s->queue1,&top);
            seqqueue_push(&s->queue2,top);
            seqqueue_pop(&s->queue1);
        }
    }
    else
    {
        while(1)
        {
            if(s->queue2.size == 1)
            {
                seqqueue_pop(&s->queue2);
                return;
            }
            seqqueue_gettop(&s->queue2,&top);
            seqqueue_push(&s->queue1,top);
            seqqueue_pop(&s->queue2);
        }
    }
}

取栈顶元素

int stackqueue_gettop(stackqueue *s,seqqueuetype *value)
{
    if(s == NULL || value == NULL)
    {
        return 0;
    }
    seqqueuetype top
    if(s->queue1.size != 0)
    {
        while(1)
        {
            if(s->queue1.size == 1)
            {
                seqqueue_gettop(&s->queue1,value);
                return 1;
            }
            seqqueue_pop(&s->queue1);
        }
    }
    else
    {
        while(1)
        {
            if(s->queue2.size == 1)
            {
                seqqueue_gettop(&s->queue2,value);
                return 1;
            }
            seqqueue_pop(&s->queue2);
        }
    }
}

下面是测试函数以及结果验证
这里写图片描述
这里写图片描述


如有错误请指出,谢谢

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值