表达式求值

/**
* 功能:表达式求值(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

測试数据:
9+8/4*(2+1)/2#

输出结果是:
12

这个表达式哪里来的?反正不是我自己想的,是一位大神用来測试他的算术表达式的,我就拿来測试我的程序呗


注意:输入表达式后一定要加一个#才干够!!!

PS:蛋疼死了,明明早就成功了,结果codeblocks由于路径不能是中文搞得我没法调试,浪费时间,还有就是開始得到的老是错误结果,然后我就把程序断点运行了一遍之后,就该了一块地方,可是我认为应该没影响的地方啊!!!然后竟然就成功了!!!!吓尿,还有就是一定要输入完算术表达式后加一个#表示输入结束,不然是得不到正确结果的!!!

【足迹C++primer】表达式求值的更多相关文章

  1. 数据结构算法C语言实现(八)--- 3.2栈的应用举例:迷宫求解与表达式求值

    一.简介 迷宫求解:类似图的DFS.具体的算法思路可以参考书上的50.51页,不过书上只说了粗略的算法,实现起来还是有很多细节需要注意.大多数只是给了个抽象的名字,甚至参数类型,返回值也没说的很清楚, ...

  2. 表达式求值(noip2015等价表达式)

    题目大意 给一个含字母a的表达式,求n个选项中表达式跟一开始那个等价的有哪些 做法 模拟一个多项式显然难以实现那么我们高兴的找一些素数代入表达式,再随便找一个素数做模表达式求值优先级表 - ( ) + ...

  3. 用Python3实现表达式求值

    一.题目描述 请用 python3 编写一个计算器的控制台程序,支持加减乘除.乘方.括号.小数点,运算符优先级为括号>乘方>乘除>加减,同级别运算按照从左向右的顺序计算. 二.输入描 ...

  4. nyoj305_表达式求值

    表达式求值 时间限制:3000 ms  |  内存限制:65535 KB 难度:3   描述 Dr.Kong设计的机器人卡多掌握了加减法运算以后,最近又学会了一些简单的函数求值,比如,它知道函数min ...

  5. 利用栈实现算术表达式求值(Java语言描述)

    利用栈实现算术表达式求值(Java语言描述) 算术表达式求值是栈的典型应用,自己写栈,实现Java栈算术表达式求值,涉及栈,编译原理方面的知识.声明:部分代码参考自茫茫大海的专栏. 链栈的实现: pa ...

  6. 数据结构--栈的应用(表达式求值 nyoj 35)

    题目链接:http://acm.nyist.net/JudgeOnline/problem.php?pid=35 题目: 表达式求值 时间限制:3000 ms | 内存限制:65535 KB描述 AC ...

  7. NOIP2013普及组 T2 表达式求值

    OJ地址:洛谷P1981 CODEVS 3292 正常写法是用栈 #include<iostream> #include<algorithm> #include<cmat ...

  8. HNU 12817 Shipura(表达式求值)

    题目链接:http://acm.hnu.cn/online/?action=problem&type=show&id=12817 解题报告:定义两种运算符号,一种是>>,就 ...

  9. NOIP201302表达式求值

    NOIP201302表达式求值 题目描述 Description 给定一个只包含加法和乘法的算术表达式,请你编程计算表达式的值. 输入描述 Input Description 输入仅有一行,为需要你计 ...

随机推荐

  1. Codeforces 543D Road Improvement(DP)

    题目链接 Solution 比较明显的树形DP模型. 首先可以先用一次DFS求出以1为根时,sum[i](以i为子树的根时,满足要求的子树的个数). 考虑将根从i变换到它的儿子j时,sum[i]产生的 ...

  2. 第五篇、 WebSphere8.5的安装

    一.前言 WebSphere Application  Server 是IBM企业级应用服务器,与WAS6,WAS7相比较而言 WAS8发生了很大的改变,其安装介质和以前截然不同,该篇章中对于不同的安 ...

  3. PHP+MySQL中对UTF-8,UTF8(utf8),set names gbk 的理解

    问题一:在我们进行数据库操作时会发现,数据库中表的编码用的是utf-8,但是在进行dos命令是要使用set names gbk (一)Mysql中默认字符集设置有四级:服务器级,数据库级,表级,和字段 ...

  4. Java学习----创建对象的数组

    1.初始化数组的长度 2.初始化每个元素对象 3.调用每个对象的方法 public class Student { private String name; public Student() {} p ...

  5. 关于考虑浏览器兼容性时间的工具demo

    //支持跨浏览器的添加事件. var btn = document.getElementById("btn"); function showMes() { alert(" ...

  6. 缓存淘汰算法---LRU

    1. LRU1.1. 原理 LRU(Least recently used,最近最少使用)算法根据数据的历史访问记录来进行淘汰数据,其核心思想是“如果数据最近被访问过,那么将来被访问的几率也更高”. ...

  7. jQuery API中文文档

    jQuery API中文文档 http://www.css88.com/jqapi-1.9/category/events/event-handler-attachment/ jQuery UI AP ...

  8. 那些年被我坑过的Python——牵一发动全身 第十一章MySQL、ORM

    #!/usr/bin/env python # -*- coding:utf-8 -*- __Author__ = "Zhang Xuyao" from sqlalchemy im ...

  9. openerp report image

    webkit : 再mako 文件中插入以下代码, <% %>标签用于再mako中定义代码或者函数. 然后  ${ embed_image('图片类型', 图片字段 , 宽度,高度)  } ...

  10. 关于pcre正则表达式库libpcre

    gcc 4.8中已经包含了std regex的头文件 可是没有实现,所以链接是失败的 gcc 4.9完整的支持了c++ 11的regex. 在4.9以前,可以寻求boost的regex. 不过,我更熟 ...