青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

最近在網上看到一個求解數學表達式程序,感覺很不錯,故拿出來修改之后供大家一起分享.
程序如下:
#include <ctype.h> //打開庫文件
#include <stdio.h>
#include <iostream.h>
#include <malloc.h>
#include <process.h>
#include <string.h>

#define error 0
#define ok 1
typedef struct{
? int *base;
? int *top;
? int stacksize;
}sqstack;

class CExpression
{
public:
?CExpression();
?~CExpression();
public:
?void initstack(sqstack &s);
?int gettop(sqstack &s);
?void push(sqstack &s,int e);
?int pop(sqstack &s,int &e);
?int setfind(char a,char b[]); //查找a在b中的位置
?char precede(char op1,char op2,int &flag); //比較op1和op2的優先級
??? int numlink(int opd,int ops,int &flag); //數字與字符串的連接
?int operate(int n1,char o,int n2,int &flag);//運算
??????????? /*
??????????? flag為一個標志變量,
??????????? 1為表達式有誤!除數為0!
??????????? 2為表達式的值過大或過小
??????????? 3為未知類型的錯誤,可能沒有這一點
??????????? 但為了容錯,還是要加上這一點
?-*/
public:
?sqstack opnd;
?sqstack optr;
private:
?sqstack s;
};

CExpression::CExpression()
{
?s.top=s.base;
}

CExpression::~CExpression()
{
}

void CExpression::initstack(sqstack &s)
{
?s.base=(int *)malloc(10*sizeof(int));
?if(!s.base) exit(1);
?s.top=s.base;
?s.stacksize=100;
}

int CExpression::gettop(sqstack &s)
{
?int e;
?e=*(s.top-1);
?return e;
}

void CExpression::push(sqstack &s,int e)
{
??? if(s.top-s.base>=s.stacksize)
?{
??s.base=(int*)realloc(s.base,(s.stacksize+10*sizeof(int)));
??if(!s.base)
???exit(2);
??s.top=s.base+s.stacksize;
??s.stacksize+=10;
?}
?*s.top++=e;
}

int CExpression::pop(sqstack &s,int &e)
{
?if(s.top==s.base)return error;
?e=*--s.top;
?return ok;
}

int CExpression::setfind(char a,char b[])
{
?int i,j;
?i=-1,j=0;
?while(b[j]!='\0')
??if(a==b[j++]) {i=j-1;break;}
??return i;
}

char CExpression::precede(char op1,char op2,int &flag) //比較op1和op2的優先級
{
?int i,j;
?char st1[8]={"+-*/()#"}; //運算符初始化
?char st2[7][8]={">><<<>>",">><<<>>",">>>><>>", //比較操作初始化
??">>>><>>","<<<<<= ",">>>> >>","<<<<< ="};
?i=setfind(op1,st1);j=setfind(op2,st1);
?if (i>-1 && j>-1) //如果你所輸入的運算符不在+-*/()#內,返回ERROR
?{return st2[i][j];flag=ok;}
?else flag=error;
?return error;
}

int CExpression::numlink(int opd,int ops,int &flag){ //數字與字符串的連接
?int aa=ops;
?ops=ops*10+opd-48;
?if (ops<0 && aa>0 || aa>214748364)
??flag=error; else flag=ok; //flag=0,說明ops已經過大,
?return ops;
}

int CExpression::operate(int n1,char o,int n2,int &flag){ //運算
??????????? /*
??????????? flag為一個標志變量,
??????????? 1為表達式有誤!除數為0!
??????????? 2為表達式的值過大或過小
??????????? 3為未知類型的錯誤,可能沒有這一點
??????????? 但為了容錯,還是要加上這一點
?-*/
?
?int result=0;
?switch (o){
?case '+': //加法運算
??flag=0;result=n1+n2;
??if (n1>=0 && n2>=0 && result<0 || n1<=0 && n2<=0 && result>0)
???//兩個大于0的數相加,和小于0,或兩個小于0的數相加,和大于0,返回錯誤
??{flag=2;return error;}
??else
??{flag=0;return result;}
??break;
?case '-': //減法運算
??flag=0;result=n1-n2;
??if (n1>=0 && n2<0 && result<0 || n1<=0 && n2>0 && result>0)
???//一個大于0的數減一個小于0 的數,和小于0或一個小于0 的數減去一個大于0的數,返回錯誤
???
??{flag=2;return error;}
??else
??{flag=0;return result;}
??break;
?case '*': //乘法運算
??flag=0;result=n1*n2;
??if (n1>=0 && n2>=0 && result<0 || n1<=0 && n2<=0 && result>0)
???//兩個大于0的數相乘,積小于0,或兩個小于0的數相乘,積大于0,返回錯誤
??{flag=2;return error;}
??else
??{flag=0;return result;}
??break;
?case '/': //除法運算
??if(n2!=0) //如果被除數為0要返加ERROR
??{flag=0;return n1/n2;break;}
??else
???//除數為0,返回錯誤
??{flag=1;return error;break;}
?}
?flag=3;return error;
}

void main()
{
?CExpression expression;
//?sqstack opnd; //用于存放運算數
//?sqstack optr; //用于存放運算符
?int theta; //用于存放一個運算符
?int a,b; //用于存放用于操作的兩個數
?int temp; //一個臨時的變量
?int flag2=0; //一個標志變量,用于判斷是否要連接數字
?int flag1; //一個標志變量,用于判斷表達式是否是無效的
?int cn=0; //用于存放字符的位置
?int ops=0; //用于存放當前的操作數
?char st1[255]; //表達式中最多有255個字符
?char c; //用于表示當前的字符
?for (a=0;a<255;a++) st1[a]='#'; //對數組初始化
?expression.initstack(expression.opnd); //對棧OPND初始化
?expression.initstack(expression.optr); //對棧OPTR初始化
?expression.push(expression.optr,'#');
?cin>>st1;
?temp=strlen(st1);
?if (st1[temp-1]!='#') st1[temp]='#'; //對表達式的結尾加入一個#
?
?c=st1[0];
?while(c!='#' || expression.gettop(expression.optr)!='#'){ //cout<<st1;
??
??c=st1[cn];
??if(isdigit(c)) {
???ops=expression.numlink(c,ops,temp);
???if (temp==ok)
???{
????if (flag2) expression.pop(expression.opnd,temp);
????flag2=1;
????expression.push(expression.opnd,ops);
????cn++;
????continue;
???}
???else
???{cout<<"表達式的值過大,無法計算!"<<endl;return;}
??}
??else{
???ops=0;
???flag2=0;
???temp=expression.precede(expression.gettop(expression.optr),c,temp); //temp為precede中的一個代號,為ok為正確的運算符比較,為error為錯誤的運算符比較
???if (temp==error) {cout<<"表達式有誤!無法求解!"<<endl;return;} //錯誤的運算符比較時,返回.
???switch (temp){
???case '<':
????expression.push(expression.optr,c);cn++;break; //如果為<,操作符入棧
???case '=':
????expression.pop(expression.optr,temp);cn++;break; //如果為=,操作符出棧
???case '>': //如果為>,執行運算操作
????expression.pop(expression.optr,theta);
????expression.pop(expression.opnd,b);
????expression.pop(expression.opnd,a);
????expression.operate(a,theta,b,flag1);
????if (flag1==1) {cout<<"表達式有誤!除數不能為0!"<<endl;return;}
????else if(flag1==2) {cout<<"表達式的值過大或過小,無法計算!"<<endl;return;}
????else if(flag1==3) {cout<<"未知道類型的錯誤!"<<endl;return;}
????expression.push(expression.opnd,expression.operate(a,theta,b,flag1));
????break;
???case ' ':
????cout<<"表達式有誤!無法求解!"<<endl;return;
???} //end switch
??} //end if
?} //end while
?a=expression.gettop(expression.opnd);
?cn=0;
?while(st1[cn]!='#') cout<<st1[cn++]; //輸出你所輸入字符串
?cout<<"=";
?cout<<a<<endl; //輸出最終結果
}

該程序的缺點是不能處理存在小數的表達式.


只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


posts - 4, comments - 4, trackbacks - 0, articles - 0

Copyright © 瘋蝶雨人

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            国产精品久久久久9999| 久久国产主播精品| 久久成人精品视频| 欧美一区二区日韩一区二区| 亚洲色在线视频| 亚洲欧美日韩国产另类专区| 午夜精品999| 久久久久看片| 国产亚洲成人一区| 国产日韩精品一区二区三区| 国产欧美日韩一区| 亚洲国产裸拍裸体视频在线观看乱了 | 在线免费观看日本欧美| 国产精品一级久久久| 欧美自拍丝袜亚洲| 欧美日韩第一区| 欧美伊人久久久久久久久影院 | 在线免费观看视频一区| 亚洲一区二区三区在线看 | 夜夜嗨av一区二区三区四季av| 欧美大胆成人| 9久re热视频在线精品| 亚洲一区二区三区在线视频| 亚洲视频久久| 欧美承认网站| 久久国产成人| 亚洲精品小视频在线观看| 亚洲丰满在线| 国产精品一二三| 久久嫩草精品久久久久| 91久久国产综合久久| 日韩午夜激情| 午夜影院日韩| 欧美在线不卡视频| 亚洲欧美一区二区视频| 久久免费视频在线| 久久精品夜色噜噜亚洲a∨| 亚洲国内精品| 国产自产在线视频一区| 亚洲一级影院| 欧美日韩和欧美的一区二区| 久久久精品999| 亚洲精品久久久久中文字幕欢迎你 | 久久国产精品久久精品国产| 一区二区久久久久| 久久国产乱子精品免费女| 久久久久久久久久久久久9999| 亚洲黄色在线观看| 欧美一区网站| 国产精品综合网站| 亚洲视频1区2区| 91久久精品美女| 嫩模写真一区二区三区三州| 狠狠色狠狠色综合日日91app| 亚洲视频精品| 一区二区欧美日韩视频| 欧美日产在线观看| 一区二区三区欧美视频| 亚洲精品黄色| 欧美日韩国产综合视频在线观看| 亚洲精品一区久久久久久| 亚洲高清视频的网址| 欧美成年人视频网站欧美| 在线观看视频免费一区二区三区| 久久阴道视频| 久热精品视频| 亚洲精品乱码久久久久| 91久久久久| 国产精品久久久久久久app| 亚洲免费视频中文字幕| 亚洲一级二级| 国产专区一区| 亚洲国产美国国产综合一区二区| 欧美激情中文字幕乱码免费| 一区二区三区日韩精品视频| 一区二区三区欧美视频| 国产日韩欧美一区二区三区四区| 久久久99国产精品免费| 久久一区二区精品| 美女91精品| 亚洲美女av在线播放| 亚洲精品乱码久久久久久日本蜜臀 | 蜜桃久久av| 亚洲精选国产| 一本久道久久综合狠狠爱| 国产精品亚洲综合一区在线观看| 久久视频这里只有精品| 欧美精品一二三| 久久激情视频免费观看| 免费视频最近日韩| 午夜精品三级视频福利| 久久一区免费| 亚洲欧美日韩中文播放| 久热爱精品视频线路一| 亚洲欧美清纯在线制服| 久久久久久久欧美精品| 亚洲天堂网站在线观看视频| 久久国产精品毛片| 一本色道**综合亚洲精品蜜桃冫 | 久久爱另类一区二区小说| 91久久久一线二线三线品牌| 亚洲一区二区三区成人在线视频精品| 一色屋精品视频在线看| 一本久久综合亚洲鲁鲁| 在线观看一区视频| 亚洲欧美制服另类日韩| 日韩视频在线免费| 久久精品国产免费看久久精品| 亚洲美女毛片| 久久精品91| 欧美一区二区视频97| 欧美日韩高清在线播放| 蜜臀久久99精品久久久画质超高清| 欧美午夜激情视频| 亚洲激情小视频| 尤物九九久久国产精品的分类| 宅男精品视频| 一区二区三区福利| 欧美大片免费| 欧美国产乱视频| 一区二区亚洲精品| 欧美怡红院视频一区二区三区| 亚洲一区二区三区精品动漫| 欧美国产日韩一区二区三区| 老司机亚洲精品| 国产一区二区按摩在线观看| 亚洲午夜视频在线观看| 亚洲视频中文字幕| 欧美日韩精品一区| 亚洲裸体视频| 亚洲性视频h| 欧美日韩一区二区三区在线视频 | 久久久视频精品| 国产三级精品在线不卡| 亚洲一区二区三区乱码aⅴ蜜桃女| 欧美成人性生活| 亚洲高清在线| 99re国产精品| 欧美日韩不卡视频| 99亚洲一区二区| 午夜精品久久久久久久男人的天堂| 欧美精品日韩精品| 夜色激情一区二区| 亚洲一品av免费观看| 国产精品国产三级国产a| 亚洲一区二区在线视频 | 噜噜噜在线观看免费视频日韩| 国模精品一区二区三区色天香| 久久gogo国模裸体人体| 久久综合久久久久88| 亚洲成人在线视频网站| 欧美成在线观看| 一区二区免费在线播放| 香蕉久久夜色精品国产| 狠狠爱综合网| 欧美精品123区| 亚洲一区在线免费观看| 久久精品国产免费| 亚洲成色www8888| 欧美久久一区| 午夜精彩视频在线观看不卡| 毛片一区二区三区| 99国产麻豆精品| 国产日韩欧美在线播放| 免播放器亚洲一区| 一本久久综合亚洲鲁鲁| 久久欧美中文字幕| 一区二区三区四区五区视频| 国产精品久久久久久久浪潮网站| 欧美在线影院在线视频| 亚洲毛片在线看| 久久青青草原一区二区| 亚洲视频一区二区在线观看| 国产一区在线看| 欧美日本国产精品| 久久国产精品高清| 亚洲作爱视频| 欧美成人情趣视频| 欧美亚洲三区| 9l国产精品久久久久麻豆| 国产亚洲一区二区三区在线播放 | 国产精品乱子乱xxxx| 久久综合五月天婷婷伊人| 亚洲一区二区三区欧美| 最近中文字幕mv在线一区二区三区四区 | 国内精品写真在线观看| 欧美激情一区| 久久久久88色偷偷免费| 亚洲午夜免费视频| 亚洲精品久久在线| 免费欧美高清视频| 欧美在线观看天堂一区二区三区| 亚洲欧洲一区二区三区久久| 国产亚洲综合精品| 国产精品丝袜91| 欧美日韩一区二区欧美激情 | 欧美一二三区精品| 亚洲少妇在线| 亚洲看片免费| 亚洲黄色片网站|