4.线性数据结构——3.栈及例题

标准库的栈

  • 定义:stack<typename> myStack;
  • 大小:size()
  • 压栈:push()
  • 弹栈:pop()
  • 栈顶:top()
  • 判空:empty()
#include <cstdio>
#include <string>
#include <map>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
using namespace std;int main() {stack<int> myStack;printf("%d\n",myStack.size());for (int i = 0; i < 10; ++i) {myStack.push(i);}printf("%d\n",myStack.size());while(!myStack.empty()){printf("%d\n",myStack.top());myStack.pop();}printf("stack is empty.");return 0;
}

例题

在这里插入图片描述
【提交地址】

分析

int:4byte
unsigned:4byte
long long:8byte
unsigned long long:8byte

代码

#include <cstdio>
#include <string>
#include <map>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
using namespace std;int main() {stack<long long> myStack;int n;scanf("%d",&n);for (int i = 0; i < n; ++i) {long long temp;scanf("%lld",&temp);myStack.push(temp);}while(!myStack.empty()){printf("%lld ",myStack.top());myStack.pop();}return 0;
}

括号匹配

在这里插入图片描述

#include <cstdio>
#include <string>
#include <map>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
using namespace std;int main() {char buf[200];while(fgets(buf,200,stdin) != NULL){string str = buf;str.pop_back();//去掉额外的换行stack<unsigned> indexStack;//存储左圆括号下标string res;//保存输出结果for (unsigned i = 0; i < str.size(); ++i) {if (str[i]=='('){indexStack.push(i);res.push_back('$');} else if(str[i]==')'){if (indexStack.empty()){res.push_back('?');} else{res.push_back(' ');res[indexStack.top()]=' ';indexStack.pop();}}else{res.push_back(' ');}}printf("%s\n%s\n",str.c_str(),res.c_str());}return 0;
}

计算器

在这里插入图片描述
【提交地址】

思路

  • 使用map,表示各运算符之间的优先级,以便后续的比较
  • 维护两个栈,一个double类型的数据栈,一个char类型的运算符栈
  • 输入控制,输入使用fgets存入一个char数组中,然后定义一个字符串formula接收数组中存的算式,字符串使用pop_back()排除末尾的换行符
  • 接下来根据表达式的长度,对字符串formula从左往右进行遍历:
    • 如果输入的是数字,设置一个字符串num接收
    • 如果输入的是空格,如果num非空,表明空格前是刚输入的数字,需要把num的内容转化成double类型数据,压入数据栈中,然后将num值置为空;如果num已经为空,表明空格前输入的是运算符,不需要操作
    • 其他的情形:
      • 输入的是终结符’$',结尾之前若num非空,,那么将num的数据转为double压入数据栈,运算符压入运算符栈中
      • 输入的是运算符
        • 如果之前运算符栈为空,那么压入运算符栈中
        • 如果之前运算符栈非空
          • 如果当前运算符优先级大于栈顶运算符优先级,那么压入运算符栈中
          • 如果当前运算符优先级小于栈顶运算符优先级,从运算符栈弹出栈顶运算符,依次弹出数据栈栈顶两个数据,第一个弹出的作为右运算符,第二个弹出的作为左运算符,然后计算得到值压入数据栈中;最后运算符压入运算符栈中
  • 结束,输出结果

代码

#include <cstdio>
#include <string>
#include <map>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
using namespace std;int main() {char form[1000];map<char,int> priority={{'$',0},{'+',1},{'-',1},{'*',2},{'/',2},};while(fgets(form,1000,stdin) != NULL){string formula = form;formula.pop_back();if (formula == "0"){break;}formula.push_back('$');//补充一个虚拟终止符string num;//用来收集单独的数字以组成一个数字stack<double> number;stack<char> option;for (unsigned i = 0; i < formula.size(); ++i) {if (formula[i]>='0'&&formula[i]<='9'){num.push_back(formula[i]);}else if(formula[i]==' '){if (num != ""){number.push(stod(num));//stod=>string to doublenum="";}}else{if (formula[i]=='$'){if (num != ""){number.push(stod(num));//stod=>string to doublenum="";}}while(!option.empty()&&priority[option.top()]>=priority[formula[i]]){//新来的运算符优先级不高于栈顶的优先级char oper = option.top();option.pop();double rhs = number.top();number.pop();double lhs = number.top();number.pop();switch (oper) {case '+':number.push(lhs+rhs);break;case '-':number.push(lhs-rhs);break;case '*':number.push(lhs*rhs);break;case '/':number.push(lhs/rhs);break;}}//比expr[i]优先级更高的运算都计算过了option.push(formula[i]);}}printf("%.2lf",number.top());}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/757044.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

视觉信息处理和FPGA实现第5次作业-Matlab实现图像逆时针旋转90度

一、Matlab2022a安装 链接&#xff1a;https://pan.quark.cn/s/6e177bc7c11d 提取码&#xff1a;dKNN 二、Matlab使用 2.1 新建一个脚本文件&#xff08;.m文件&#xff09; 2.2 另存为到便于归档的地方 考虑到.m文件如果不是全英文路径&#xff0c;也有可能会出问题&#…

Linux 服务升级:MySQL 主从(半同步复制) 平滑升级

目录 一、实验 1.环境 2.Mysql-shell 检查工具兼容性 3.逻辑备份MySQL数据 4.备份MySQL 数据目录、安装目录、配置文件 5.MySQL 升级 6.master节点 使用systemd管理mysql8 7. slave1 节点升级 8. slave2 节点升级 9.半同步设置 二、问题 1.mysqldump备份报错 2.Inn…

Docker部署dart-frog服务

参考&#xff1a; dart-frog官网&#xff1a;https://dartfrog.vgv.dev/docs/overview 使用 Dart Frog 体验 Dart 服务端开发 - 简书 打包项目 按照demo新增项目后&#xff0c;执行&#xff1a; dart_frog build 等待build后生成 build 文件夹&#xff0c;这个文件夹就是需要…

【爬虫】专栏文章索引

为了方便 快速定位 和 便于文章间的相互引用等 作为一个快速准确的导航工具 爬虫 目录&#xff1a; &#xff08;一&#xff09;web自动化和接口自动化 &#xff08;二&#xff09;实战-爬取Boss直聘信息数据

详细分析Python模块中的雪花算法(附模板)

目录 前言1. 基本知识2. 模板3. Demo 前言 分布式ID的生成推荐阅读&#xff1a;分布式ID生成方法的超详细分析&#xff08;全&#xff09; 1. 基本知识 Snowflake 算法是一种用于生成全局唯一 ID 的分布式算法&#xff0c;最初由 Twitter 设计并开源 它被设计用于解决分布式…

使用甘特图实现高效时间规划

甘特图虽然看似简单,却蕴含着规划时间的奥秘。它将复杂的工序分解成逻辑严密的任务链条,每个短小的条形图块都清晰地道出一个任务的起始、持续和终止。就像指挥家挥舞手中的棒,每个动作都精确拍着节奏,确保各个乐手分工合作、行云流水。择一个好用的甘特图制作工具,会让你事半功…

C#,图论与图算法,有向图(Graph)之环(Cycle)判断的颜色算法与源代码

1 检查该图是否包含循环 给定一个有向图,检查该图是否包含循环。如果给定的图形至少包含一个循环,则函数应返回true,否则返回false。 方法:深度优先遍历可用于检测图中的循环。连接图的DFS生成树。只有当图中存在后缘时,图中才存在循环。后边是从节点到自身(自循环)或…

.NET 异步编程(异步方法、异步委托、CancellationToken、WhenAll、yield)

文章目录 异步方法异步委托async方法缺点CancellationTokenWhenAllyield 异步方法 “异步方法”&#xff1a;用async关键字修饰的方法 异步方法的返回值一般是Task<T>&#xff0c;T是真正的返回值类型&#xff0c;Task<int>。惯例&#xff1a;异步方法名字以 Asy…

linux之centos7vmware虚拟机的安装

目录 一、下载合适的vmware和操作系统镜像安装文件 来自引用文章的软件下载本片文章使用的软件下载 二、根据教程进行安装 三、网络配置解说 四、配置网络 编辑虚拟机网络 对VMWARE虚拟机网络进行配置 设置虚拟机网络为NAT模式 设置自定义网络为 VMnet8(NAT模式) 编辑li…

Panasonic松下PLC如何数据采集?如何实现快速接入IIOT云平台?

在工业自动化领域&#xff0c;数据采集与远程控制是提升生产效率、优化资源配置的关键环节。对于使用Panasonic松下PLC的用户来说&#xff0c;如何实现高效、稳定的数据采集&#xff0c;并快速接入IIOT云平台&#xff0c;是摆在他们面前的重要课题。HiWoo Box工业物联网关以其强…

WordPress站点如何实现发布文章即主动推送到神马搜索引擎?

平时boke112百科很少关注到神马搜索引擎&#xff0c;近日有站长留言想要实现WordPress站点发布文章就主动推送到神马搜索引擎&#xff0c;而且推送成功就自动添加一个自定义字段&#xff0c;以防重复推送。 登录进入神马站长平台后才知道神马也有一个API推送功能&#xff0c;不…

Tcl学习笔记(一)——环境搭建及基本语法

一、Tcl简介 TCL&#xff08;Tool Command Language&#xff0c;即工具命令语言&#xff09;是一种解释执行的脚本语言。所谓解释执行语言&#xff0c;是指其不需要通过编译和联结&#xff0c;而是直接对每条语句进行顺序解释、执行。 TCL包含语言和工具库&#xff0c;TCL语言主…

UE5拷贝复制快捷键修改Ctrl+w

UE5默认修改了原来的Ctrl w的快捷键方式&#xff0c;改成Ctrl D 非常不习惯 其实可以在编辑器中进行修改快捷键的 位置在 Editor Preferences &#xff0c;搜索 Duplicate&#xff0c; 在其中的command selection中&#xff0c;修改 按键为Ctrl w 如图所示&#xff1b; …

LeetCode 面试经典150题 380.O(1)时间插入、删除和获取随机元素

题目&#xff1a; 实现RandomizedSet 类&#xff1a; RandomizedSet() 初始化 RandomizedSet 对象bool insert(int val) 当元素 val 不存在时&#xff0c;向集合中插入该项&#xff0c;并返回 true &#xff1b;否则&#xff0c;返回 false 。bool remove(int val) 当元素 va…

C# 方法(函数)

文章目录 C# 方法&#xff08;函数&#xff09;简单示例程序代码运行效果 值传递和引用传递示例程序 运行效果按输出传递参数运行结果 C# 方法&#xff08;函数&#xff09; 简单示例 程序代码 访问的限制符 using System; using System.Collections.Generic; using Syste…

R语言:microeco:一个用于微生物群落生态学数据挖掘的R包,第八:trans_func class

# 生态学研究人员通常对微生物群落的功能特征感兴趣&#xff0c;因为功能或代谢数据对于解释微生物群落的结构和动态以及推断其潜在机制是强有力的。 # 由于宏基因组测序复杂且昂贵&#xff0c;利用扩增子测序数据预测功能谱是一个很好的选择。 # 有几个软件经常用于此目标&…

性能优化(CPU优化技术)-NEON指令详解

原文来自ARM SIMD 指令集&#xff1a;NEON 简介 &#x1f3ac;个人简介&#xff1a;一个全栈工程师的升级之路&#xff01; &#x1f4cb;个人专栏&#xff1a;高性能&#xff08;HPC&#xff09;开发基础教程 &#x1f380;CSDN主页 发狂的小花 &#x1f304;人生秘诀&#xf…

Qt5.9.6+VS2015 部署PCL1.8.1

本文系转载&#xff0c;如侵权请告知删除。原博文链接&#xff1a;https://blog.csdn.net/jepco1/article/details/80752954 0 编译环境 所需软件包及其版本 Qt5.9.6 msvc2015_64 VS2015 VTK 8.0.0 https://gitlab.kitware.com/vtk/vtk/tree/v8.0.0 PCL1.8.1 https://github.c…

蓝桥杯刷题(十二)

1.答疑 代码 n int(input()) L [] for i in range(n):a,b,c map(int,input().split())A ab # 进入和答疑时间B abc # 个人总用时L.append([A,B]) L.sort(keylambda x:x[1]) # 个人总用时短的优先 ans tmp 0 # ans为发消息时刻&#xff0c;tmp为前一个人的总用时 for i …

Linux:Gitlab:16.9.2 创建用户及项目仓库基础操作(2)

我在上一章介绍了基本的搭建以及邮箱配置 Linux&#xff1a;Gitlab:16.9.2 (rpm包) 部署及基础操作&#xff08;1&#xff09;-CSDN博客https://blog.csdn.net/w14768855/article/details/136821311?spm1001.2014.3001.5501 本章介绍一下用户的创建&#xff0c;组内设置用户&…