【足迹C++primer】表达式求值
表达式求值
/**
* 功能:表达式求值(0到9)
* 时间:2014年6月15日08:02:31
* 作者:cutter_point
*/ #include<stdlib.h>
#include<stack>
#include<iostream>
#include<string> using namespace std; stack<int> intStack; //存放数值的栈
stack<char> charStack; //存放运算符 string OP="+-*/()#"; //等会用finf_first_of来找出来全部的数
string shuzhi="0123456789"; //推断运算符的优先级,c1表示前面元素,c2在c1之后
char isFirst(char c1, char c2)
{
char res='#'; switch(c1)
{
case '+': case '-': //推断前面是+和-的情况
switch(c2)
{
case '+': case '-': case ')': case '#':
res='>'; //加减的优先级比他们高,碰到就让前面的出栈计算
break;
case '*': case '/': case '(':
res='<'; //加减的优先级比他们低,当碰到的时候直接进栈
break;
}
break;
case '*': case '/': //推断前面是*和/的情况
switch(c2)
{
case '(':
res='<';
break;
default:
res='>';
break;
}
break;
case '(':
switch(c2)
{
case ')':
res='=';
break;
default:
res='<';
break;
}
break;
case ')':
res='>';
break;
case '#':
switch(c2)
{
case '#':
res='=';
break;
default:
res='<';
break;
}
break;
} return res;
} //推断是否是运算符
bool In(char c, string OP)
{
bool b=false; for(string::iterator it=OP.begin() ; it != OP.end() ; ++it)
{
if(c == *it)
{
b=true;
break;
} } return b;
} //得到计算结果
int countResult(int a, char opera, int b)
{
int res=0; switch(opera)
{
case '+':
res=a+b;
break;
case '-':
res=a-b;
break;
case '*':
res=a*b;
break;
case '/':
res=a/b;
break;
} return res;
} int result(string s)
{
//得到算术表达式的值 //首先让charStack栈的栈顶变为'#'
charStack.push('#');
//循环对栈进行操作
string::iterator it=s.begin();
while(it != s.end())
{
if(!In(*it, OP))
{
//首先把字符转化成数字
int a=*it-'0';
intStack.push(a);
++it;
}
else
{
switch(isFirst(charStack.top(), *it))
{
case '<': //优先级比前面的小,那就直接进栈
charStack.push(*it);
++it;
break;
case '=':
charStack.pop();//弹出栈顶元素,脱括号继续循环
++it;
break;
case '>': //对栈进行各种操作,退栈并将运算结果入栈
int b=intStack.top(); //得到前面一个数值
intStack.pop(); //吧栈顶的元素删除
int a=intStack.top(); //得到第二个数字
intStack.pop(); //删除栈顶元素
//取出运算符号
char opera=charStack.top(); //得到栈顶元素
charStack.pop(); //删除栈顶元素 //进行计算
intStack.push(countResult(a, opera, b));
break;
}//switch
}//else
}//while cout<<"结果是:"<<intStack.top()<<endl; return intStack.top();
} /*
//找到string看是否是运算符
bool isYunSuanFu(string s)
{
bool b=false; string::size_type pos=0; if(pos=s.find_first_of(OP, pos) != string::npos)
{
b=true;
} return b;
}
*/ int main()
{
string s;
cout<<"输入算术表达式:"<<endl;
while(cin>>s)
{
cout<<"计算结果是:"<<endl;
cout<<result(s)<<endl;
} // string::size_type pos=0;
// shuzhi.erase(pos,1); 删除的结果是123456789
// cout<<shuzhi; return 0;
} //蛋疼调试结束:2014年6月15日11:53:01
这个表达式哪里来的?反正不是我自己想的,是一位大神用来測试他的算术表达式的,我就拿来測试我的程序呗
PS:蛋疼死了,明明早就成功了,结果codeblocks由于路径不能是中文搞得我没法调试,浪费时间,还有就是開始得到的老是错误结果,然后我就把程序断点运行了一遍之后,就该了一块地方,可是我认为应该没影响的地方啊!!!然后竟然就成功了!!!!吓尿,还有就是一定要输入完算术表达式后加一个#表示输入结束,不然是得不到正确结果的!!!
【足迹C++primer】表达式求值的更多相关文章
- 数据结构算法C语言实现(八)--- 3.2栈的应用举例:迷宫求解与表达式求值
一.简介 迷宫求解:类似图的DFS.具体的算法思路可以参考书上的50.51页,不过书上只说了粗略的算法,实现起来还是有很多细节需要注意.大多数只是给了个抽象的名字,甚至参数类型,返回值也没说的很清楚, ...
- 表达式求值(noip2015等价表达式)
题目大意 给一个含字母a的表达式,求n个选项中表达式跟一开始那个等价的有哪些 做法 模拟一个多项式显然难以实现那么我们高兴的找一些素数代入表达式,再随便找一个素数做模表达式求值优先级表 - ( ) + ...
- 用Python3实现表达式求值
一.题目描述 请用 python3 编写一个计算器的控制台程序,支持加减乘除.乘方.括号.小数点,运算符优先级为括号>乘方>乘除>加减,同级别运算按照从左向右的顺序计算. 二.输入描 ...
- nyoj305_表达式求值
表达式求值 时间限制:3000 ms | 内存限制:65535 KB 难度:3 描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min ...
- 利用栈实现算术表达式求值(Java语言描述)
利用栈实现算术表达式求值(Java语言描述) 算术表达式求值是栈的典型应用,自己写栈,实现Java栈算术表达式求值,涉及栈,编译原理方面的知识.声明:部分代码参考自茫茫大海的专栏. 链栈的实现: pa ...
- 数据结构--栈的应用(表达式求值 nyoj 35)
题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=35 题目: 表达式求值 时间限制:3000 ms | 内存限制:65535 KB描述 AC ...
- NOIP2013普及组 T2 表达式求值
OJ地址:洛谷P1981 CODEVS 3292 正常写法是用栈 #include<iostream> #include<algorithm> #include<cmat ...
- HNU 12817 Shipura(表达式求值)
题目链接:http://acm.hnu.cn/online/?action=problem&type=show&id=12817 解题报告:定义两种运算符号,一种是>>,就 ...
- NOIP201302表达式求值
NOIP201302表达式求值 题目描述 Description 给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值. 输入描述 Input Description 输入仅有一行,为需要你计 ...
随机推荐
- php 备份数据库脚本
<?php// 备份数据库$host = "localhost";$user = "root"; //数据库账号$password = "123 ...
- 24种设计模式--代理模式【Proxy Pattern】
什么是代理模式呢?我很忙,忙的没空理你,那你要找我呢就先找我的代理人吧,那代理人总要知道被代理人能做哪些事情不能做哪些事情吧,那就是两个人具备同一个接口,代理人虽然不能干活,但是被代理的人能干活呀. ...
- yii2源码学习笔记(五)
Event是所有事件类的基类.它封装了与事件相关的参数. yii2\base\Event.php <?php /** * @link http://www.yiiframework.com/ * ...
- 总结几种C#窗体间通讯的处理方法
摘要:本文介绍了C#窗体间通讯的几种处理方法,即传值.继承.事件回调,希望对大家有用. http://www.cnblogs.com/jara/p/3439603.html 应用程序开发中,经常需要多 ...
- 升级Python至2.7.8,并安装django
1:下载Python-2.7.8.tgz2:步骤:tar -zxvf Python-2.7.8.tgzcd Python-2.7.8./configure -h --查看configure选项./co ...
- 在 iOS 应用中直接跳转到 AppStore 的方法--备用
找到应用程序的描述链接,比如:http://itunes.apple.com/gb/app/yi-dong-cai-bian/id391945719?mt=8 然后将 http:// 替换为 itms ...
- Pair of Numbers
Codeforces Round #209 (Div. 2) D:http://codeforces.com/contest/359/problem/D 题意:给以一个n个数的序列,然后问你最大的区间 ...
- 深入浅出 Java Concurrency (1) : J.U.C的整体认识
转 http://www.blogjava.net/xylz/archive/2010/06/30/324915.html 去年年底有一个Guice的研究计划,可惜由于工作“繁忙”加上实际工作中没有用 ...
- “adb server is out of date. killing.... ADB server didn't ACK * failed to start daemon * ”
草泥马的adb: “adb server is out of date. killing.... ADB server didn't ACK * failed to start daemon * ” ...
- 同一张表不同SESSION相互持有对方记录引发的死锁
锁产生的原因:如果有两个会话,每个会话都持有另一个会话想要的资源,此时就会发生死锁. 同一张表不同SESSION持有不同记录 SQL> create table t1(id int); Tabl ...