百鸡问题
这是一个三元一次问题,并对三个根的和做了要求。我们将三个数的范围作出限制,先限制公鸡个数,公鸡个数*5小于等于钱数,与此同时,母鸡个数*3小于等于钱数,小鸡个数则直接由多少只鸡减去公鸡母鸡的个数就可以得到,如此一直循环,并满足钱数与个数的要求时,就可以输出最后的结果。
#include<iostream>
using namespace std;
int main(){
int a=0,b,c,d,x,y,z,m;
int e=0;
cin>>x>>y>>z>>a>>m;
for(int b=0;b*x<=a;b++){
for(int c=0;c*y<=a;c++){
d=(a-b*x-y*c)*z;
if(b*x+c*y+d/z==a&&d>=0&&b+c+d==m){
e++;
}
}
}
cout<<e<<endl;
return 0;
}
