c++ - stack、queue使用与模拟实现


一、stack的使用

1、接口函数与作用

接口作用
stack< T >构造一个空栈
push(val)将val压入栈中
pop()出栈
size()栈的元素个数
top()取出栈顶元素的引用
empty()判断栈是否为空

2、使用

void test01()
{
	//构造一个空栈
	stack<int> sta;

	//进栈
	sta.push(1);
	sta.push(2);
	sta.push(3);
	sta.push(4);
	sta.push(5);

	//大小
	cout <<"size:"<< sta.size() << endl;

	//是否为空
	while (!sta.empty())
	{
		cout << sta.top() << " ";
		//出栈
		sta.pop();
	}
}

在这里插入图片描述

二、queue使用

1、接口函数与作用

接口作用
queue< T >构造一个空队列
push(val)val入队
pop()出队
size()队列的元素个数
front()取出队头元素的引用
back()取出队尾元素的引用
empty()判断栈是否为空

2、使用

void  test02()
{
	//构造一个空队列
	queue<int> q;

	//进队
	q.push(1);
	q.push(2);
	q.push(3);
	q.push(4);
	q.push(5);

	//大小
	cout << "size:" << q.size() << endl;

	//判断是否为空
	while (!q.empty())
	{
		//取队头
		cout << q.front() << " ";
		//出队
		q.pop();
	}
}

在这里插入图片描述

三、stack、queue的模拟实现

1、容器适配器
适配器是一种设计模式(设计模式是一套被反复使用的、多数人知晓的、经过分类编目的、代码设计经验的总
结),该种模式是将一个类的接口转换成客户希望的另外一个接口。

2、stack、queue就属于容器适配器,stack、queue是对deque容器的封装。
如:
在这里插入图片描述
在这里插入图片描述
我们也可以不使用默认的容器如:
(前提:重新指定的容器要具有相应的接口)

void test03()
{
	stack<int,vector<int>> sta;
	sta.push(1);
	sta.push(2);

	while (!sta.empty())
	{
		cout << sta.top() << " ";
		sta.pop();
	}
}

在这里插入图片描述

3、deque容器
deque容器具有头删尾删,头插尾插等接口且效率还不错,我们下面就模拟栈、队列都使用该容器。

4、stack的模拟实现
stack的接口实现都是复用了deque容器的接口。

//T是数据类型,Con是容器类型,默认使用deque容器
template<class T, class Con = deque<T>>
class stack
{
public:
	//构造函数
    stack()
    {}
	//压栈
    void push(const T& x)
    {
        _c.push_back(x);
    }
	
	//出栈
    void pop()
    {
        _c.pop_back();
    }
	
	//取栈顶引用
    T& top()
    {
        return _c.back();
    }
	
    const T& top()const
    {
        return  _c.back();
    }
	
	//大小
    size_t size()const
    {
       return  _c.size();
    }
	
	//判断是否为空
    bool empty()const
    {
        return _c.empty();
    }

private:
	//构造一个deque容器
    Con _c;

};

5、queue的模拟实现
也是复用deque容器的接口

template<class T, class Con = deque<T>>

class queue

{

public:
	
	//构造
    queue() {};
	
	//进队
    void push(const T& x)
    {
        _c.push_back(x);
    }
	
	//出队
    void pop()
    {
        _c.pop_front();
    }
	
	//队尾元素的引用
    T& back()
    {
        return _c.back();
    }
	
    const T& back()const
    {
        return _c.back();
    }
	
	//队头元素的引用
    T& front()
    {
        return _c.front();
    }

    const T& front()const
    {
        return _c.front();
    }
	
	//大小
    size_t size()const
    {
        return _c.size();
    }
	
	//是否为空
    bool empty()const
    {
        return _c.empty();
    }

private:
	//构造一个deque容器
    Con _c;
};

6、测试

void test_stack()
{
	xu::stack<int> sta;
	sta.push(1);
	sta.push(2);
	sta.push(3);
	sta.push(4);

	cout <<sta.size() << endl;

	while (!sta.empty())
	{
		cout << sta.top() << " ";
		sta.pop();
	}

	cout << endl;
}

void test_queue()
{
	xu::queue<int> q;
	q.push(1);
	q.push(2);
	q.push(3);
	q.push(4);
	q.push(5);

	cout << q.size() << endl;

	while (!q.empty())
	{
		cout << q.front() << " ";
		q.pop();
	}

	cout << endl;
}

在这里插入图片描述

  • 7
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以用两个队列来模拟一个栈的数据结构,具体实现如下: 1. 定义两个队列queue1和queue2; 2. 将元素压入栈时,将元素放入queue1中; 3. 将元素弹出栈时,先将queue1中的元素依次出队并放入queue2中,直到queue1中只剩一个元素,将该元素出队返回即可; 4. 在弹出元素时,如果queue1中只有一个元素,直接出队返回即可,不需要将元素放入queue2中; 5. 在弹出元素时,交换queue1和queue2的指针,使得下一次弹出时可以从另一个队列中取出元素; 6. 使用两个队列实现的栈,其空间复杂度为O(n),其中n为栈中元素的个数。 以下是使用C语言实现的代码: ``` #include <stdio.h> #include <stdlib.h> typedef struct Queue { int* data; int front; int rear; } Queue; typedef struct Stack { Queue* queue1; Queue* queue2; } Stack; Queue* createQueue(int size) { Queue* queue = (Queue*)malloc(sizeof(Queue)); queue->data = (int*)malloc(sizeof(int) * size); queue->front = 0; queue->rear = 0; return queue; } Stack* createStack(int size) { Stack* stack = (Stack*)malloc(sizeof(Stack)); stack->queue1 = createQueue(size); stack->queue2 = createQueue(size); return stack; } void push(Stack* stack, int value) { stack->queue1->data[stack->queue1->rear] = value; stack->queue1->rear++; } int pop(Stack* stack) { int value = 0; if(stack->queue1->front == stack->queue1->rear) { printf("Stack is empty.\n"); return -1; } while(stack->queue1->front < stack->queue1->rear - 1) { stack->queue2->data[stack->queue2->rear] = stack->queue1->data[stack->queue1->front]; stack->queue1->front++; stack->queue2->rear++; } value = stack->queue1->data[stack->queue1->front]; stack->queue1->front++; Queue* temp = stack->queue1; stack->queue1 = stack->queue2; stack->queue2 = temp; return value; } int main() { Stack* stack = createStack(10); push(stack, 1); push(stack, 2); push(stack, 3); printf("%d\n", pop(stack)); push(stack, 4); printf("%d\n", pop(stack)); printf("%d\n", pop(stack)); printf("%d\n", pop(stack)); printf("%d\n", pop(stack)); return 0; } ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值