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缓存,//字母不分大小写 当然,不只能算矩阵,还能算数= = ...
随机推荐
- 微信小程序-视图模板
定义模板 使用name属性,作为模板的名字.然后在<template/>内定义代码片段,如: <!-- index: int msg: string time: string --& ...
- centos 带S权限的二进制
早上写的一个用find查找带S权限的,感觉不记一下可惜了. [root@iZ28wg1kditZ ~]# find / -type f -exec ls -al {} \;|awk 'BEGIN {p ...
- 过目不忘JS正则表达式
正则表达式,有木有人像我一样,学了好几遍却还是很懵圈,学的时候老明白了,学完了忘光了.好吧,其实还是练的不够,所谓温故而知新,可以为师矣,今天就随我来复习一下这傲娇的正则表达式吧. 为啥要有正则表达式 ...
- em和rem
em是一个相对值,是相对于父元素的值. body{ font-size:62.5%;/*10/16*100%=62.5%*/ } h1{ font-size:2.4em;/*2.4em*10=24px ...
- Visual Studio最常用、最高效的快捷键
查了一些VS编程的快捷键,大家共同学习,共同进步! 1.强迫智能感知:Ctrl+J.智能感知是Visual Studio最大的亮点之一,选择Visual Studio恐怕不会没有这个原因. 2.强迫显 ...
- test 2016-12-28
// dpm(variable_get('node_submitted_page'));// //0// dpm(variable_get('language_count'));// //i3 = i ...
- JavaScript 深入了解基本类型和引用类型的值
转载:https://segmentfault.com/a/1190000006752076 一个变量可以存放两种类型的值,基本类型的值(primitive values)和引用类型的值(refere ...
- angularjs自定义指令
my-directive为指令名称,thisdata为绑定的数据 <span ng-repeat="act in move.casts" style="positi ...
- JavaScript函数定义和调用 变量作用域
本文是笔者在看廖雪峰老师JavaScript教程时的个人总结 JavaScript中函数定义可以是这样的格式 function 函数名(参数) { 函数体 } 也可以是这样的格式 ...
- 为 iTween 指定特定的回调 : onupdate, oncomplete
问题地址:Specifying a delegate for the value of onupdate in iTween 1.找到 void CallBack 2.修改以下代码: void Cal ...