信息发布软件,b2b软件,广告发布软件

标题: C++表达式全部拽在这就这么简单的完集了 [打印本页]

作者: 群发软件    时间: 2017-6-14 21:06
标题: C++表达式全部拽在这就这么简单的完集了
本帖最后由 群发软件 于 2017-6-14 21:08 编辑

C++表达式全部拽在这就这么简单的完集了
将输入的表达式转化成后缀表达式,然后对后缀表达式进行运算
二、将算式转化为后缀表达式:
1、从左向右读取输入的运算符
2、若为数字将数字写入字符串A中
3、若为运算符,与栈顶的运算符比较优先级
3-1、若栈为空或为‘(’则直接压入栈中
3-2、若优先级高直接压入到栈中
3-3、若优先级低或相等则将栈顶的元素弹出并放入到A中,再与新的栈顶元素比较
4、若为括号
4-1、若为(则将其直接要入到栈中
4-2、若为)则从栈顶开始弹出元素依次放入到A中直到遇到(并删除这对括号
5、重复上述步骤直到算式读完
注:因为遇到优先级相同或更高的运算符号时要将栈顶的运算符弹出并加入到字符串中,所以相邻的运算符的数量小于等于二,所以在3-3处最多只需判断两次即可。
三、运算
1、读取刚刚转化成后缀表达式的字符串A,从左向右读取
2、若为操作数,则将其压入到栈B中
3、若为运算符,则读取并弹出栈堆上的两个元素进行运算(先出的元素为第一个元素),将结果压入到栈中成为新的栈顶元素。
4、重复上述两个步骤直到A结束,结果为栈顶元素。
C++代码
Cal.h
#ifndef CAL_H_INCLUDED#define CAL_H_INCLUDED#include<stack>#include <string>#include<iostream>using namespace std;class Cal{public :    string tran();//将输入的字符串转化成后缀表达式    double result();//运算函数public :    Cal();    Cal(string a);private:    string exp;    stack<char> oper;//存放运算符的字符串};#endif // CAL_H_INCLUDED//Cal.cpp #include "Cal.h"double Cal::result(){    string fin=tran();    stack<int> s;    for(size_t i= 0;i<fin.length();i++)    {        if(fin>='0'&&fin<='9')        {            s.push(fin-'0');        }        else if(fin=='*')        {            int a,b;            a=s.top();            s.pop();            b=s.top();            s.pop();            s.push(a*b);        }        else if(fin=='-')        {            int a,b;            a=s.top();            s.pop();            b=s.top();            s.pop();            s.push(a-b);        }        else if(fin=='+')        {            int a,b;            a=s.top();            s.pop();            b=s.top();            s.pop();            s.push(a+b);        }        else if(fin=='/')        {            double a,b;            a=s.top();            s.pop();            b=s.top();            s.pop();            if(b!=0)                s.push(b/a);        }    }    return s.top();}string Cal::tran(){    string a;    for(size_t i = 0; i < exp.length(); i++)    {        if(exp>='0'&&exp<='9')        {            a+=exp;         }        else if(exp=='+'||exp=='-')        {            if(oper.empty()||oper.top()=='(')            {                oper.push(exp);            }            else if(oper.top()=='+'||oper.top()=='-')            {                a+=oper.top();                oper.pop();                oper.push(exp);            }            else if(oper.top()=='*'||oper.top()=='/')            {                a+=oper.top();                oper.pop();                if(!oper.empty())                {                    a+=oper.top();                    oper.pop();                }                oper.push(exp);            }        }        else if(exp=='*'||exp=='/')        {            if(oper.empty()||oper.top()=='(')            {                oper.push(exp);            }            else if(oper.top()=='+'||oper.top()=='-')            {                oper.push(exp);            }            else if(oper.top()=='*'||oper.top()=='/')            {                a+=oper.top();                oper.pop();            }        }        else if(exp=='(')        {            oper.push(exp);        }        else if(exp==')')        {            while(oper.top()!='(')            {                a+=oper.top();                oper.pop();            }            oper.pop();        }    }    while(!oper.empty())    {        a+=oper.top();        oper.pop();    }    return a;}Cal::Cal(string a) : exp(a){} #include  < iostream> #include "Cal.h"using namespace std;int main(){    string s;    while((cin >> s)!=NULL)    {        Cal c(s);    cout << c.result() << endl;    }    return 0;}
“`
注:
1、将字符串转换成数字的时候要减’0’。
2、进行除法运算的时候栈顶的元素为除数,下一个元素才是被除数
3、本代码是参考网上大神代码写的有非常非常多的不足(比如没有对/0进行进一步处理,只能进行int的运算等),仅供初学STL栈的新人参考,如有不足见谅

 昨天晚上,我花了大把的时间研究里面二叉树应用解决计算表达式的问题,一直就没理解,主要是觉得是不是自己错了,又懒,不愿意自己把代码敲到电脑里看看,结果浪费了很多时间。所以还是提醒大家,代码这种东西,有什么好多看的,觉得他错了就自己敲到电脑里去看看!其实也没错太多,就是少了一些东西,导致原代码里的括号完全没有意义,也就是说,书中的代码虽然考虑到了计算表达式中的括号,却什么都没有做,而这其实只要稍稍改进:加一个flag存储上次读到的char,如果是‘)’的话,就要把左式当成运算数来计算。
  好了,把正确的代码贴在下面:
  #include <iostream>
  using namespace std;
  class calc
  {
  enum Type {DATA, ADD, SUB, MULTI, DIV, OPAREN, CPAREN, EOL};
  struct node
  {
  Type type;
  int data;
  node *lchild, *rchild;
  node(Type t, int d=0, node *lc=NULL, node *rc=NULL)
  {
  type=t; data=d; lchild=lc; rchild=rc;
  }
  };
  node *root;
  node *create(char * &s);
  Type getToken (char * &s, int &value);
  int result (node *t);
  public:
  calc (char *s) {root=create(s);}
  int result() {if (root==NULL) return 0;
  return result(root);}
  };
  calc::node *calc::create(char * &s)
  {
  node *p, *root=NULL;
  Type returnType,flag=DATA;
  int value;
  while (*s)
  {
  flag=returnType;
  returnType=getToken(s,value);
  switch (returnType)
  {
  case DATA:
  case OPAREN:
  if (returnType == DATA) p=new node(DATA,value);
  else p=create(s);
  if (root==NULL) root=p;
  else if (root->rchild==NULL) root->rchild=p;
  else root->rchild->rchild=p;
  break;
  case CPAREN:
  case EOL: return root;
  case ADD:
  case SUB:
  root=new node(returnType,0,root);
  break;
  case MULTI:
  case DIV:
  if (root->type==DATA || root->type==MULTI || root->type==DIV || flag==OPAREN)
  root=new node(returnType,0,root);
  else root->rchild=new node(returnType,0,root->rchild);
  }
  }
  return root;
  }
  calc::Type calc::getToken(char *&s, int &data)
  {
  char type;
  while (*s==' ') ++s;
  if (*s>='0' && *s<='9')
  {
  data=0;
  while (*s>='0' && *s<='9') {data=data*10+ *s-'0'; ++s;}
  return DATA;
  }
  if (*s == '\0') return EOL;
  type =*s; ++s;
  switch(type)
  {
  case '+':return ADD;
  case '-':return SUB;
  case '*':return MULTI;
  case '/':return DIV;
  case '(':return OPAREN;
  case ')':return CPAREN;
  default: return EOL;
  }
  }
  int calc::result(node *t)
  {
  int num1,num2;
  if (t->type == DATA) return t->data;
  num1=result(t->lchild);
  num2=result(t->rchild);
  switch(t->type)
  {
  case ADD:t->data=num1+num2;break;
  case SUB:t->data=num1-num2;break;
  case MULTI: t->data=num1*num2;break;
  case DIV:t->data=num1/num2;break;
  }
  return t->data;
  }
  int main()
  {
  char equation[256];
  cin>>equation;
  //calc exp("3*(2+(6/2))");
  calc exp(equation);
  cout<<exp.result()<<endl;
  return 0;
  }


作者: lalajie    时间: 2017-6-18 08:35
,很高端的视觉效应,很耐心,设计的很不错,高端大气上档次啊!技术人员很给力,专业的就是专业的,为卖家耐心热情的服务态度点个赞!下次有需要还会来!~
作者: jzgsjt    时间: 2017-6-23 01:49
宝买的最超值的虚拟物品了吧。大赞。给077号客服一个好评,休假都还给我改需求。而且速度超快,刚说完的改动需求,不到5分钟就搞定了。顺便给我的网站打个广告,手赚咖shouzhuanka.com各种手机赚钱方式。
作者: 乱世扶稣    时间: 2017-6-28 15:32
平台很好用,功能够强大,关键是物美价廉,且有后期技术指导。
作者: a001hao    时间: 2017-7-4 17:04
衍了事的嫌疑
作者: anleeycn    时间: 2017-7-5 05:02
好,页面设计很满意,而且也很快,非常有效率,第一次买,遇到这么好的卖家,这么高效的服务,真的太幸运了,太谢
作者: jskf10    时间: 2017-7-12 02:51
来的,挺满意的,客服也比较也耐心~回头会介绍人过来的




欢迎光临 信息发布软件,b2b软件,广告发布软件 (http://postbbs.com/) Powered by Discuz! X3.2