百元买百鸡问题,代码无误,却输出不了结果。用逻辑运算符也不行



#include<stdio.h>
int main()
{
    
    int b, m, s;
    for (b = 0; b <= 20; b++)
        for (m = 0;m <= 33; m++)
            for (s = 3; s <= 99; s++)
                if(b * 5 + m * 3 + s / 3 == 100&& b + m + s == 100&& s % 3 == 100)
                //if (b * 5 + m * 3 + s / 3 == 100)
                    //if (b + m + s == 100)
                        //if (s % 3 == 100)
                            printf("公鸡%d只,母鸡%d只,小鸡%d只\n", b, m, s);
    return 0;

}

你if语句里面的条件语句有问题,逻辑运算符的优先级比赋值运算符高,你不打括号就全乱了。
不打括号实际是这样运算的:
if( (b * 5 + m * 3 + s / 3) == (100&& b + m + s) == (100&& s % 3) == 100)

但实际上你应该这样写:
if( (b * 5 + m * 3 + s / 3 == 100) && (b + m + s == 100) && (s % 3 == 100) ) )
而且应该用或而不是与。
再者,你第三个for循环应该是s+=3而不是s++。
这种逻辑判断,我建议打好括号,不管你是否了解运算符的优先级。