問題是,如果程序計算的第一個動作(取決於操作順序)除以0(例如7/0 + 3或3 + 7/0),它將打印錯誤消息但執行下一個操作。三位數運算計算器
例 -
輸入:7/0 + 2 ----->輸出:您無法通過zero.7/0 + 2 = 2
它應該做的劃分 - - >輸出:你不能被零除。
它發生是因爲我無法得到它跳過下一個開關的行動。如果你有一個想法或知道如何解決它,請幫助。 謝謝
P.S 如果你知道更好的方法來解決操作順序問題,請幫助。
縮短代碼: 只需輸入類似7 + 4/0或7-4/0
#include"stdafx.h"
using namespace System;
#include<iostream>
using namespace std;
int main()
{
long double num1, num2, num3, res;
char action1, action2;
cin >> num1 >> action1 >> num2 >> action2 >> num3;
if ((action2 == '*' || action2 == '/') && (action1 == '-' || action1 == '+')) //action2 will be preformed before action1 (Order of operation)
{
switch (action2) //I didn't include the options for '+' or '-' because the if statement requires action2 to be '*' or '/'.
{
case('/'):
if(num3==0)
cout<< "Error, you can't divide by zero";
else
res = num2/num3;
break;
default:
cout << "Input not recognized";
break;
}
switch (action1)
{
case('+'):
cout << num1 << "+" << num2 << action2 << num3 << "=" << res + num1;
break;
case('-'):
cout << num1 << "-" << num2 << action2 << num3 << "=" << res - num1;
break;
default:
cout << "Input not recognized";
break;
}
}
cout << "\n\n";
system("PAUSE");
return 0;
}
全碼:
// Three numbers Calculator
/*Known problems: when the first action is divided by zero the programs prints the error message but runs the next action.
Other than that I think most of the stuff works but I need to check*/
#include "stdafx.h"
using namespace System;
#include<iostream>
using namespace std;
int main()
{
cout << "Enter action as # to exit program" << endl;
cout << "Possible actions:+,-,*,/\n" << endl;
int a = 1; //loop veriable
while (a == 1) //loop
{
long double num1, num2, num3, res;
char action1, action2;
cin >> num1 >> action1 >> num2 >> action2 >> num3;
if ((action2 == '*' || action2 == '/') && (action1 == '-' || action1 == '+')) //action2 will be preformed before action1 (Order of operation)
{
switch (action2) //I didn't include the options for '+' or '-' because the if statement requires action2 to be '*' or '/'.
{
case('/'):
if (num3 == 0) //The problem I described at the top occurs here and at another place below
cout << "You can't divide by zero.";
else
res = num2/num3;
break;
case('*'):
res = num2*num3;
break;
default:
cout << "Input not recognized";
break;
}
switch (action1) //I didn't include the options for '*' or '/' because the if statement requires action1 to be '+' or '-'.
{
case('+'):
cout << num1 << "+" << num2 << action2 << num3 << "=" << res + num1;
break;
case('-'):
cout << num1 << "-" << num2 << action2 << num3 << "=" << res - num1;
break;
default:
cout << "Input not recognized";
break;
}
}
else //action1 will be performed before action2 (Order of operation)
{
switch (action1)
{
case('+'):
res = num1 + num2;
break;
case('-'):
res = num1 - num2;
break;
case('/'):
if (num2 == 0) //The problem I described at the top occurs here and at anothe place above
cout << "You can't divide by zero.";
else
res = num1/num2;
break;
case('*'):
res = num1*num2;
break;
case('#'):
system("PAUSE");
return 0;
break;
default:
cout << "Input not recognized";
break;
}
switch (action2)
{
case('+'):
cout << num1 << action1 << num2 << "+" << num3 << "=" << res + num3;
break;
case('-'):
cout << num1 << action1 << num2 << "-" << num3 << "=" << res - num3;
break;
case('/'):
if (num3 == 0)
cout << "You can't divide by zero.";
else
res = num2/num3;
break;
case('*'):
res = num2*num3;
break;
case('#'):
system("PAUSE");
return 0;
break;
default:
cout << "Input not recognized";
break;
}
}
cout << "\n\n";
}
}
對於操作的順序,你可能希望看到綴以postifx轉換及其評價。 – Sniper