这个程序的重点是输入一个2位数字,如果该数字小于或等于15,则返回该数字的平方,如果该数字大于或等于16且小于或等于30,则返回其总和s 个数字,如果大于或等于 31,则应返回其数字的乘积。
这是我到目前为止编写的代码:
#include <iostream>
using namespace std;
int main()
{
int a;
cout << "dati a: ";
cin >> a;
if (a >= 100 || a)
{
cout << "a trebuie sa aiba 2 cifre" << endl
<< "mai dati incercati o data: ";
}
if (a <= 15)
{
cout << a * a;
}
else if (16 <= a <= 30)
{
cout << a / 10 + a % 10;
}
else if (a >= 31)
{
cout << (a / 10) * (a % 10);
}
}
Run Code Online (Sandbox Code Playgroud)
我编译并运行它,测试是这样的。我给它 10,它返回 100,我给它 23,它返回 5,我给它 29,它返回 11,我给它 31,它返回 4,我给它 38,它返回 11。我倾向于相信它会去最后一个 else if,但我不知道真正的原因。
表达式else if (16 <= a <= 30)很可能不是按照您的预期执行,它与以下内容相同:
else if ((16 <= a) <= 30)
Run Code Online (Sandbox Code Playgroud)
计算布尔表达式的第一部分,无论结果如何,都会使整个表达式为真:
else if (1 <= 30) // if it's true
else if (0 <= 30) // if it's false
Run Code Online (Sandbox Code Playgroud)
我相信你想要:
else if (a >= 16 && a <= 30)
Run Code Online (Sandbox Code Playgroud)
一般来说,编译器可以将这种构造检测为可能有问题,尽管它在任何方面都不是无效的,但这是不寻常的。这只是设置编译器警告的问题,这将取决于您的特定工具链,您可以在此处找到一些一般说明:
| 归档时间: |
|
| 查看次数: |
97 次 |
| 最近记录: |