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缓存,//字母不分大小写 当然,不只能算矩阵,还能算数= = ...
随机推荐
- 看守所、戒毒所3D指纹门禁系统解决方案
为响应"科技强警"的战略方针,华本构建了一个完整的.集成的.可靠的.易操作的高安全性门禁系统,应用于看守所.戒毒所.公安局和部队等单位,使管理更现代化.规范化,有效地预防和制止越狱 ...
- IOS7 edgesForExtendedLayout
在iOS 7中,苹果引入了一个新的属性,叫做[UIViewController setEdgesForExtendedLayout:],它的默认值为UIRectEdgeAll.当你的容器是naviga ...
- Node聊天程序实例02:chat_server.js
作者:vousiu 出处:http://www.cnblogs.com/vousiu 本实例参考自Mike Cantelon等人的<Node.js in Action>一书. chat_s ...
- Bluetooth Low Energy 嗅探
Bluetooth Low Energy 嗅探 路人甲 · 2015/10/16 10:52 0x00 前言 如果你打开这篇文章时期望看到一些新的东西,那么很抱歉这篇文章不是你在找的那篇文章.因为严格 ...
- CentOS6.4x64_安装Qt5
1.安装Qt5.3.2x86 由于 OS是x64,Qt是x86,∴需要在 系统中安装相关的32位的程序(比如 报错"bad elf interpreter"的时候 就需要" ...
- PHP JSON
- 【图像】Matlab图像标定工具箱
参考教程: Matlab工具箱教程 http://www.vision.caltech.edu/bouguetj/calib_doc/ 摄像机模型 http://oliver.zheng.blog ...
- [ubunut]打造Ubuntu下Java开发环境 (转)
http://www.cnblogs.com/wufengtinghai/p/4542366.html 遇到困难: A Java Runtime Environment (JRE) or Java D ...
- Can't connect to local MySQL server through socket '/tmp/mysql.sock'
找不到/tmp/mysql.sock这个文件,需要查找/tmp/mysql.sock文件位置,并在/etc/my.cnf里面配置 [client]socket=/var/lib/mysql/mysql ...
- eclipse svn提交报错
修改文件格式:右键-properties-text file encoding-other UTF-8