栈的应用 - 简单计算器

2024-08-27 23:08
文章标签 简单 应用 计算器

本文主要是介绍栈的应用 - 简单计算器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

A

E - 简单计算器
Crawling in process... Crawling failed Time Limit:1000MS     Memory Limit:32768KB     64bit IO Format:%I64d & %I64u
Submit Status Practice HDU 1237

Description

读入一个只包含 +, -, *, / 的非负整数计算表达式,计算该表达式的值。

Input

测试输入包含若干测试用例,每个测试用例占一行,每行不超过200个字符,整数和运算符之间用一个空格分隔。没有非法表达式。当一行中只有0时输入结束,相应的结果不要输出。

Output

对每个测试用例输出1行,即该表达式的值,精确到小数点后2位。

Sample Input

     
1 + 2 4 + 2 * 5 - 7 / 11 0

Sample Output

     
3.00 13.36
最应该注意的问题,简单的说是栈的转移
#include<stdio.h> #include<stack> #include<algorithm> #include<string.h> #include<stdlib.h> using namespace std;
int main(){
char  b[220]; char a [220][220]; while(gets(b)){  memset(a,0,sizeof(a)); if(strcmp(b,"0")==0)break; stack<double> snum; stack<char>schar; stack<char>cchar; stack<double>cnum; int z = 0; int x = 0; int length = strlen(b); //printf("长度是%d\n",length);/// for(int i=0;i<length;i++){ if(b[i] != ' '){ a[z][x++] = b[i]; } else { z++; x = 0; } } //for(int i=0;i<=z;i++){ // printf("%s\n",a[i]);/// //} x = 0; int y = 0; char fuhao[210]; double num[220]; for(int i=0;i<=z;i++){
if(a[i][0]>='0'&&a[i][0]<='9'){ double xx = (double)atoi(a[i]); num[x++] = xx; } else fuhao[y++] = a[i][0]; } // for(int i=0;i<x;i++) //printf("%f ",num[i]); //printf("\n"); //for(int i=0;i<y;i++) //printf("%c ",fuhao[i]); //printf("\n"); int numers = x; int chars = y; x = y = 0; double ss; snum.push(num[x++]); for(int i=0;i<chars;i++){ if(fuhao[i]=='*'){  ss = num[x++] * snum.top(); snum.pop(); snum.push(ss); } else if(fuhao[i] == '/'){ ss = snum.top() / num[x++]; snum.pop(); snum.push(ss); } else { snum.push(num[x++]); schar.push(fuhao[i]); } } while(!snum.empty()){ cnum.push(snum.top()); snum.pop(); } while(!schar.empty()){ cchar.push(schar.top()); schar.pop(); } double s1 = cnum.top(); double s2 = 0; char v; cnum.pop(); while(!cnum.empty()){ s2 = cnum.top(); cnum.pop(); v = cchar.top(); cchar.pop(); if(v == '+')s1 = s1 + s2; else s1 = s1 - s2; } printf("%.2f\n",s1); /*for(int i=0;i<=z;i++){ for(int j=0;j<strlen(a[i]);j++){ printf("%c",a[i][j]); } printf("\n"); }*/ } }

这篇关于栈的应用 - 简单计算器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1113046

相关文章

C++初始化数组的几种常见方法(简单易懂)

《C++初始化数组的几种常见方法(简单易懂)》本文介绍了C++中数组的初始化方法,包括一维数组和二维数组的初始化,以及用new动态初始化数组,在C++11及以上版本中,还提供了使用std::array... 目录1、初始化一维数组1.1、使用列表初始化(推荐方式)1.2、初始化部分列表1.3、使用std::

redis群集简单部署过程

《redis群集简单部署过程》文章介绍了Redis,一个高性能的键值存储系统,其支持多种数据结构和命令,它还讨论了Redis的服务器端架构、数据存储和获取、协议和命令、高可用性方案、缓存机制以及监控和... 目录Redis介绍1. 基本概念2. 服务器端3. 存储和获取数据4. 协议和命令5. 高可用性6.

JAVA调用Deepseek的api完成基本对话简单代码示例

《JAVA调用Deepseek的api完成基本对话简单代码示例》:本文主要介绍JAVA调用Deepseek的api完成基本对话的相关资料,文中详细讲解了如何获取DeepSeekAPI密钥、添加H... 获取API密钥首先,从DeepSeek平台获取API密钥,用于身份验证。添加HTTP客户端依赖使用Jav

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

利用Python编写一个简单的聊天机器人

《利用Python编写一个简单的聊天机器人》这篇文章主要为大家详细介绍了如何利用Python编写一个简单的聊天机器人,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 使用 python 编写一个简单的聊天机器人可以从最基础的逻辑开始,然后逐步加入更复杂的功能。这里我们将先实现一个简单的

用Java打造简易计算器的实现步骤

《用Java打造简易计算器的实现步骤》:本文主要介绍如何设计和实现一个简单的Java命令行计算器程序,该程序能够执行基本的数学运算(加、减、乘、除),文中通过代码介绍的非常详细,需要的朋友可以参考... 目录目标:一、项目概述与功能规划二、代码实现步骤三、测试与优化四、总结与收获总结目标:简单计算器,设计

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

使用IntelliJ IDEA创建简单的Java Web项目完整步骤

《使用IntelliJIDEA创建简单的JavaWeb项目完整步骤》:本文主要介绍如何使用IntelliJIDEA创建一个简单的JavaWeb项目,实现登录、注册和查看用户列表功能,使用Se... 目录前置准备项目功能实现步骤1. 创建项目2. 配置 Tomcat3. 项目文件结构4. 创建数据库和表5.