否则如果条件被忽略

ale*_*lex 2 c++ if-statement

这个程序的重点是输入一个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,但我不知道真正的原因。

ana*_*ciu 5

表达式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)

一般来说,编译器可以将这种构造检测为可能有问题,尽管它在任何方面都不是无效的,但这是不寻常的。这只是设置编译器警告的问题,这将取决于您的特定工具链,您可以在此处找到一些一般说明:

为什么我应该总是启用编译器警告?