c語言計算器括弧
⑴ 用c語言寫計算器源代碼,要有括弧,最後以等號結尾,可以運行的,求大神
#include<stdio.h>
main()
{double a,b,s;
char ch;
printf(":輸入要計算的式子,如:10+20\n");
scanf("%lf%c%lf",&a,&ch,&b);
if(ch=='+')
s=a+b;
else
if(ch=='-')
s=a-b;
else
if(ch=='*')
s=a*b;
else
s=a/b;
printf("(%lf)%c(%lf)=%lf\n",a,ch,b,s);
}
⑵ 用C語言做個簡單的計算器 要有加減乘除 先乘後加 先算括弧里的
//給你個全新的代碼
/*輸入表達式只能包含整數,+-*/和()*/
#include<stdio.h>
#include<string.h>
int add(int x,int y);
int sub(int x,int y);
int mul(int x,int y);
int div(int x,int y);
int getach(); //用於獲取一個合法字元
int getid(); //對合法字元進行判斷處理
int cal(); //計算表達式的值
int num,curch;
int (*func[])(int x,int y)={add,sub,mul,div}; //函數指針數組,數組元素分別指向+-*/運算函數
char chtbl[]="+-*/()=";
char corch[]="+-*/()=0123456789";
void main()
{
int value;
printf("請輸入要計算的表達式,以=結束:");
getach();
while(curch!='=')
{
value=cal();
printf("結果為:%d\n",value);
printf("請輸入要計算的表達式,以=結束:");
getach();
}
}
int add(int x,int y)
{
return x+y;
}
int sub(int x,int y)
{
return x-y;
}
int mul(int x,int y)
{
return x*y;
}
int div(int x,int y)
{
return x/y;
}
int getach()
{
unsigned int i;
while(true)
{
curch=getchar();
if(curch==EOF)
return -1;
for(i=0;corch[i]&&curch!=corch[i];i++)
;
if(i<strlen(corch))
break;
}
return curch;
}
int getid()
{
int i;
if(curch>='0'&&curch<='9')
{
for(num=0;curch>='0'&&curch<='9';getach())
num=num*10+curch-'0';
return -1;
}
else
{
for(i=0;chtbl[i];i++)
{
if(chtbl[i]==curch)
break;
}
if(i<=5)
getach();
return i;
}
}
int cal()
{
int x1,x2,x3,op1,op2,i;
i=getid();
if(i==4)
x1=cal();
else
x1=num;
op1=getid();
if(op1>=5)
return x1;
i=getid();
if(i==4)
x2=cal();
else
x2=num;
op2=getid();
while((op2>=0)&&(op2<5))
{
i=getid();
if(i==4)
x3=cal();
else
x3=num;
if((op1/2==0)&&(op2/2==1))
x2=func[op2](x2,x3);
else
{
x1=func[op1](x1,x2);
x2=x3;
op1=op2;
}
op2=getid();
}
return func[op1](x1,x2);
}
⑶ 用C語言做個簡單的計算器 要有加減乘除 先乘後加 先算括弧里的
簡單的表達式求值,不追求效率的話不需要使用堆棧之類的專業演算法,只需要遞歸演算法就足夠了:
1.首先編寫遞歸計算沒有括弧的字元串表達式函數。
演算法:從頭到尾按運算符優先順序次序依次搜索運算符,在這里先搜索乘除符號再搜索加減符號,同優先順序的符號則先遇到誰就處理誰,比如先查找乘除運算符,一旦遇到乘或除運算符,就根據運算符的運算規則依次讀取操作數進行運算,運算完畢將結果轉換成字元串再放回表達式中將本次運算所涉及到的部分覆蓋掉,然後繼續向後查找並處理乘或除運算符直到結尾,本次處理完畢。按此方式再從頭到尾處理加減運算符。如果某次搜索未遇到運算符則表明表達式處理完畢,這時表達式中應該就只有一個數了。
2.編寫處理帶括弧的表達式函數。
方法:從頭到尾搜索右括弧,找到後再向前找左括弧,於是找到表達式中最內層的括弧,調用上面的子函數計算其值,用其覆蓋所處理的括弧部分,本過程遞歸執行直到沒有找到右括弧為止,表達式計算完畢。
⑷ 找了一個用C語言編寫的帶括弧運算的簡易計算器,運行結果錯的很離譜,求大神改正一下。
intmid(void)
{
intdiv;
intresult=high();
while((token=='*')||(token=='/'))//改為==,原來是=
if(token=='*')
{
match('*');
result*=high();
break;
}
elseif(token=='/')
{
match('/');
div=high();
if(div==0)
{
printf("除數為零. ");
exit(1);
}
result/=div;
break;
}
returnresult;
}
害我一頓調試。。。樓主太粗心了
其實就改了一個判斷
⑸ c語言 幫我給這個計算器加個括弧的運算
對,可以用利用棧的特性來處理加括弧的問題。具體的你可以先實現,實在不行,咱們再討論著一起做哈。畢竟我也不是啥高手,最近正在強化C的基本功。所以,,,,