这道题大致有两个重点——cin输入和printf格式控制:
忽略那些废话,我们发现,输入的文本是以“浮点型+字符型+浮点型”的格式输入的,因此,我们在使用cin输入时也必须遵循这种对应关系,不要忘了:cin默认忽略空格、Tab、回车,它会根据对象把值赋给变量,只要我们的变量类型是正确的,程序就不会报错。
然后,通过简单读题,很容易发现本题希望我们使用选择结构——难点在于,我们需要控制精度,这时就可以使用printf
printf("%.4f", num);
%f代表浮点型,%.mf就意味着保留小数点后m位
请务必牢记常用占位符
#include <iostream>
using namespace std;
int main()
{
double num_1, num_2; //定义两个浮点型变量,用来储存操作数1和操作数2
char oper; //定义一个字符型变量,用来储存运算符
cin >> num_1 >> oper >> num_2; //cin的作用已经讲了,不再赘述
if (oper == '+')
{
printf("%.4f+%.4f=%.4f", num_1, num_2, num_1 + num_2); //printf格式控制基础
}else if (oper == '-')
{
printf("%.4f-%.4f=%.4f", num_1, num_2, num_1 - num_2);
}else if (oper == '*')
{
printf("%.4f*%.4f=%.4f", num_1, num_2, num_1 * num_2);
}else if (oper == '/')
{
if (num_2 == 0)
{
cout << "Wrong!Division by zero!"; //特判,0不能做除数
}else
{
printf("%.4f/%.4f=%.4f", num_1, num_2, num_1 / num_2);
}
}else
{
cout << "Invalid operation!"; //特判,不是四则运算
}
return 0;
}
C++中也存在着流输出格式控制,感兴趣可以自行学习
#include <iostream>
#include <iomanip>
using namespace std;
int main()
{
cout.precision(4); //如果使用这条语句,那么该语句后所有的cout的精度控制均为4
double num_1, num_2;
char oper;
cin >> num_1 >> oper >> num_2;
if (oper == '+')
{
cout << fixed << setprecision(4) << num_1 << '+' << num_2 << '=' << num_1 + num_2;
}else if (oper == '-')
{
cout << fixed << num_1 << '-' << num_2 << '=' << num_1 - num_2;
}else if (oper == '*')
{
cout << fixed << num_1 << '*' << num_2 << '=' << num_1 * num_2;
}else if (oper == '/')
{
if (num_2 == 0)
{
cout << "Wrong!Division by zero!";
}else
{
cout << fixed << num_1 << '/' << num_2 << '=' << num_1 / num_2;
}
}else
{
cout << "Invalid operation!";
}
return 0;
}