当前位置: 首页 > news >正文

C++——STL——栈(stack)

栈的定义

stack )是限定仅在表的一端进行插入和删除操作的线性表,允许插入和删除的一端称
栈顶,另一端称为栈底,不含任何数据元素的栈称为空栈
栈的示意图
因为栈只能够在一端进行插入和删除,所以栈具有 先进后出的特点,类似于碗的摆放拿取。

栈的头文件

#include<stack>

栈的声明:stack<数据类型>变量名;

    stack<int>s1 ;//默认的构造函数stack<int>s2(s1);//拷贝构造函数stack<int>s3 = s1;//赋值

数据的存取

1.s1.push(element);

向栈顶添加元素

2.s1.pop;

取栈顶元素

3.s1.top();

返回栈顶元素,注意这里只是返回值,但并不删除

例子:

    s1.push(50);//向栈顶添加元素s1.push(5);s1.push(13);//这个时候栈中元素为50 5 13s1.pop();//取栈顶元素13,这个时候栈中元素为50 5 cout << s1.top() << endl;//返回栈顶元素5(但不删除)

大小操作

1.s1.empty();

如果是空,返回1;如果不是空,返回0

2..s1.size();

返回栈的大小

例子:

    //大小操作cout << s1.empty() << endl;//空返回1,不空返回0cout << s1.size() << endl;

例题:十进制变成二进制

#include<iostream>
#include<stack>
using namespace std;
int main() {//例题:十进制转化成二进制stack<int>ans;cout << "请输入一个十进制整数" << endl;int n;cin >> n ;for (int i = n; i > 0;i=i/2) {ans.push(i %2);}while(ans.size()>0) {cout<<ans.top()<<" ";ans.pop();}return 0;
}


http://www.mrgr.cn/news/13220.html

相关文章:

  • Go语言开发通过本地数据xdb文件​查询获取IP地址的归属地区及运营商名称
  • CSS中的Flexbox布局和Grid布局有什么区别?适用场景
  • WPF—画刷(使用画刷实现背景颜色渐变效果)
  • C语言—字符函数和字符串函数
  • 基于SpringBoot+Vue+MySQL的小区物业管理系统
  • YarnClient发送和接收请求源码解析
  • 如何使用ssm实现基于SSM的在线教育网站的设计与实现+vue
  • 基于SSM+小程序的垃圾分类管理系统(垃圾2)(源码+sql脚本+视频导入教程+文档)
  • Java:Calendar类
  • 【区块链 + 司法存证】区块链电子数据存证平台 | FISCO BCOS应用案例
  • 【NO.11】LeetCode经典150题-274. H 指数
  • C++/Qt 多媒体(续二)
  • C++_CH09_循环
  • 免杀笔记 ---> CS特性角度看Veh免杀
  • Ubuntu美化为类Windows风格
  • DataWhale AI夏令营-《李宏毅深度学习教程》笔记-task2
  • Qt:玩转QPainter序列三
  • 内存管理篇-14kmalloc机制实现分析
  • 如何在 Vim 中显示行号
  • 分数规划问题