#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++。
这种逻辑判断,我建议打好括号,不管你是否了解运算符的优先级。