Calculator(1.5)
Calculator(1.5)
ps.负数的处理未完成
解题过程中遇到的困难和解决
<stack>
的使用:认真研究了栈,基本上掌握了用法,与
<queue>
的区别就是队列中可以直接访问首元素而栈并不能。(debug过程让我深深体会到了使用s.pop()
时一定要确认是否为空栈!!!!!)<sstream>
的使用<sstream>
用起来比较简单,网上查了资料就可以用了,注意点就是多次转化时要记得stream.clear
,不然容易出错。后缀表达式的转化及运算
这次作业主要就是让我们理解前中后缀表达式吧...找到了一篇比较好理解的教程,总的过程比较长顺利,满足以下四个原则,照猫画虎地就转化了后缀表达式。
转化原则:
- 当读到一个操作数时,立即将它放到输出中。操作符则不立即输出,放入栈中。遇到左圆括号也推入栈中。
- 如果遇到一个右括号,那么就将栈元素弹出,将符号写出直到遇到一个对应的左括号。但是这个左括号只被弹出,并不输出。
- 在读到操作符时,如果此时栈顶操作符优先性大于或等于此操作符,弹出栈顶操作符直到发现优先级更低的元素位置。除了处理')'的时候,否则决不从栈中移走'('。操作符中,'+' '-'优先级最低,'(' ')'优先级最高。
- 如果读到输入的末尾,将栈元素弹出直到该栈变成空栈,将符号写到输出中。
命令行的使用
依旧是找!资!料!掌握了新技能,开心。
一点感想
看到题目我就懵逼了,加上拖延症晚期,4.13才开始动手...总算把大部分写完了,还有个负数的情况还没搞定,过两天再填坑吧。感觉还是挺有成就感的,希望自己以后能勤快点吧...
附上代码
Calculation.cpp
#include "Calculation.h"
Calculation::Calculation()
{
}
/*将Scan中的字符串传入*/
void Calculation::GetQueue(queue<string>tmp)
{
Q = tmp;
}
/*后缀转化是判断是否为括号*/
bool isBr(string c)
{
if(c == "(" || c == ")")
return 1;
else
return 0;
}
/*确定运算符的优先级*/
int getPri(string c)
{
if(c == "+" || c == "-")
return 1;
else if(c == "*" || c == "/")
return 2;
else if(c == "(" || c == ")")
return 0; /*将括号的优先级设为最低防止误操作*/
}
/*根据运算符进行计算*/
double Cal(char c , double a , double b)
{
switch(c)
{
case'+':return(a + b);break;
case'-':return(a - b);break;
case'*':return(a * b);break;
case'/':return(a / b);break;
}
}
/*后缀转化*/
void Calculation::Change(queue<string>Q)
{
while(Q.size() != 0)
{
string c;
c = Q.front();
/*处理运算符*/
if(c == "+" || c == "-" || c == "*" || c == "/" || c == "(" || c == ")")
{
/*传入括号时*/
if(isBr(c))
{
/*左括号不做处理*/
if(c == "(")
{
sym.push(c);
}
else
{
/*发现右括号时将栈顶元素弹出知道左括号,删除左括号*/
while(sym.top() != "(")
{
get.push(sym.top());
sym.pop();
}
sym.pop();
}
}
/*传入其他运算符时*/
else
{
/*根据运算符优先级进行弹出或传入*/
while(sym.size() != 0 && getPri(c) <= getPri(sym.top()))
{
get.push(sym.top());
sym.pop();
}
sym.push(c);
}
}
/*数字直接传入*/
else
{
get.push(c);
}
Q.pop();
}
/*Q为空栈时,将sym栈内所有运算符弹出*/
while(sym.size() != 0)
{
get.push(sym.top());
sym.pop();
}
}
/*计算过程*/
void Calculation::Ans()
{
std::stringstream stream;
double tmp;
double a;
stack<double>ans; /*存储运算值*/
/*从队首元素开始进行计算*/
while(get.size() != 0)
{
/*遇到数字直接转化为double类型入栈*/
if(get.front()[0] >= '0' && get.front()[0] <= '9')
{
stream.clear();
stream << get.front();
stream >> tmp;
ans.push(tmp);
get.pop();
}
/*遇到运算符取出栈内两个数字进行运算后再入栈*/
else
{
tmp = ans.top();
ans.pop();
a = Cal(get.front()[0] , ans.top() , tmp); /*Cal函数进行具体计算*/
ans.pop();
ans.push(a);
get.pop();
}
}
cout << ans.top() << endl; /*输出结果*/
}
Calculator(1.5)的更多相关文章
- [LeetCode] Basic Calculator II 基本计算器之二
Implement a basic calculator to evaluate a simple expression string. The expression string contains ...
- [LeetCode] Basic Calculator 基本计算器
Implement a basic calculator to evaluate a simple expression string. The expression string may conta ...
- Basic Calculator II
Implement a basic calculator to evaluate a simple expression string. The expression string contains ...
- Windows Universal 应用 – Tip Calculator
声明 以下内容取材于 Bob Tabor 的课程<Windows Phone 8.1 Development for Absolute Beginners>,链接地址为:http://ww ...
- Calculator(1.0)
Calculator(1.0) Github链接 解题过程中遇到的困难 对于c++中类和对象的使用不够明确,看了c++的视频教程学会了用类和对象来写程序. 不会使用<queue>,在网上查 ...
- 数据结构与算法(1)支线任务2——Basic Calculator
题目:https://leetcode.com/problems/basic-calculator/ Implement a basic calculator to evaluate a simple ...
- calculator
#include <stdio.h> #include <stdlib.h> typedef enum { FALSE = , TRUE }BOOL; void calcula ...
- Basic Calculator
本博客介绍leetcode上的一道不难,但是比较经典的算法题. 题目如下: Implement a basic calculator to evaluate a simple expression s ...
- Matrix Calculator
表达式分析+矩阵+计算器+寄存器=矩阵计算器 怎么想起来搞这个呢.. //刚看龙书兴致勃勃要搞表达式分析 这个寄存器比较简陋,26字母+4缓存,//字母不分大小写 当然,不只能算矩阵,还能算数= = ...
随机推荐
- php : DOM 操作 XML
DOM 操作 XML 基本用法 XML文件: person.XML <?xml version="1.0" encoding="utf-8" ?> ...
- 【java基础】成员变量和局部变量
成员变量和局部变量 根据定义变量位置的不同,可以将变量分为成员变量和局部变量 成员变量是在类范围内定义的变量 局部变量是在一个方法内定义的变量 成员变量可以分为: ...
- 红包demo
嘿嘿,红包demo import random dic={} lis=['KeLan','MonKey','Dexter','Superman','Iron Man','Robin'] def red ...
- 【oracle】 oracle学习笔记1--安装与登录
由于机器配置原因,加上也是自学,所以就没必要安装专业版的oracle,于是就安装的oracle xe版本 下载地址:http://www.oracle.com/technetwork/database ...
- 十天精通CSS3学习笔记 part2
第6章 征服CSS3选择器(上) 属性选择器 在HTML中,通过各种各样的属性可以给元素增加很多附加的信息.例如,通过id属性可以将不同div元素进行区分. 在CSS2中引入了一些属性选择器,而CSS ...
- CSS的一些小技巧
1.黑白图像img.desaturate { filter: grayscale(100%); -webkit-filter: grayscale(100%); -moz-filter: graysc ...
- 公告栏放honehoneclock和喂小老鼠flash
如果你想要放flash在公告栏,像很火的honehoneclock,就要向管理员发邮件申请js权限啦啦啦~~~~~~~Email地址:博客园 <contact@cnblogs.com> 申 ...
- ArcGIS GDB 文件中的lock文件影响复制
复制或压缩gdb文件的时候,经常碰到有lock文件,解决方法是: 在catalog中停止相应的地图服务 如果用catalog预览过相应的地图,关闭catalog
- CA02检验计划批量导入 模板在文件
*&---------------------------------------------------------------------* *& PROGRAM NAME(EN) ...
- biweb后台添加上传下载功能
1.数据库对应表添加字段 file varchar(100) 2.对应的后台 模块名/admin/addinfo.php里添加如下代码: //文件上传 if ((($_FILES[&quo ...