C++STL常用操作之stack篇

本文介绍了C++中的STL stack数据结构,讲解了其构造、常用函数以及如何利用stack进行字符串倒序输出。通过实例展示了如何利用栈处理后缀表达式和中缀表达式转换,同时提及了栈空间在递归中的应用,并提醒注意栈空间可能导致的溢出问题。最后提供了一个使用stack倒序输出字符串的完整代码示例。
摘要由CSDN通过智能技术生成

STL常用操作之stack篇


简介:

栈也是一种常用的数据结构,其特点是last in first out(后进先出)。

栈对于某些问题的处理是非常方便的,比如后缀表达式求值、中缀表达式转化为后缀表达式。

逆序输出未知长度的字符串、十进制转二进制。

等等……

#include<stack>

在这里插入图片描述

1.构造

stack<int> ss;	//一般使用空腔构造
ss.push(2);		//将整形数据2压入到栈ss中
ss.push(5);		//将整形数据5压入到栈ss中

此时栈ss如图所示:
在这里插入图片描述

2.常用函数

cout << ss.top() << endl;	//输出栈顶元素
ss.pop();					//弹出栈顶元素,此时栈顶将向下移动一个位置
cout << ss.size();			//获得栈的长度
if (ss.empty());			//判断栈是否为空

这里我们利用栈倒序输出一行中全部的字符串,顺便再利用stringstream巩固一下string部分的一些内容。

#include<iostream>
#include<stack>
#include<sstream>
#include<string>
using namespace std;
int main() {
	stack<string> ss;
	string str;
	getline(cin, str);
	stringstream STR(str);
	while (STR >> str)
		ss.push(str);
	while (!ss.empty()) {
		cout << ss.top() << endl;
		ss.pop();
	}
	return 0;
}

在这里插入图片描述


另外,提一下,栈空间的使用

我们平时写代码的时候,局部变量都会用到栈空间,比如我们经常使用递归来处理汉诺塔等递归问题。

递归就是一个很典型的栈,第一层的递归先入栈,因为是第一层,它总是最先被调用,最先入栈。

在做题的时候,栈空间是有限的,有时候会溢出,所以能将递归改为非递归的算法,一般都会使用非递归,比如斐波那契额数列求值。


stack简单使用,适用于像我这样的小白快速上手,大神请键下留情!

发现问题欢迎指正!

希望能帮助到你!不懂欢迎留言!

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Alan_Lowe

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值