百鸡问题

这是一个三元一次问题,并对三个根的和做了要求。我们将三个数的范围作出限制,先限制公鸡个数,公鸡个数*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;
}

全部评论

相关推荐

#include #include #include #include using&nbsp;namespace&nbsp;std;double&nbsp;computePay(int&nbsp;n,&nbsp;double&nbsp;a[],&nbsp;double&nbsp;sv)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;double&nbsp;total&nbsp;=&nbsp;0.0;&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0;&nbsp;i&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;total&nbsp;+=&nbsp;a[i];&nbsp;&nbsp;&nbsp;&nbsp;} if (n >= 5 &amp;&amp; total >=&nbsp;sv)&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;double&nbsp;minPrice&nbsp;=&nbsp;*std::min_element(a,&nbsp;a&nbsp;+&nbsp;n);&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;total&nbsp;-=&nbsp;minPrice;&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;total;}int&nbsp;main()&nbsp;{&nbsp;&nbsp;&nbsp;&nbsp;int&nbsp;n;&nbsp;&nbsp;&nbsp;&nbsp;double&nbsp;sv; cin >> n >>&nbsp;sv;&nbsp;&nbsp;&nbsp;&nbsp;vector&nbsp;prices(n);&nbsp;&nbsp;&nbsp;&nbsp;for&nbsp;(int&nbsp;i&nbsp;=&nbsp;0;&nbsp;i&nbsp; std::cin >>&nbsp;prices[i];&nbsp;&nbsp;&nbsp;&nbsp;}&nbsp;&nbsp;&nbsp;&nbsp;double&nbsp;result&nbsp;=&nbsp;computePay(n,&nbsp;prices.data(),&nbsp;&nbsp;sv);&nbsp;&nbsp;&nbsp;&nbsp;cout&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;return&nbsp;0;}computePay&nbsp;函数参数:n:&nbsp;商品的数量。a:&nbsp;商品价格的数组。sv:&nbsp;最低支付金额。功能:计算所有商品的总价格。如果&nbsp;n&nbsp;大于等于5且总价格大于等于&nbsp;sv,则从总价格中减去最便宜的商品的价格。返回最终的支付金额。main&nbsp;函数功能:从用户输入中读取商品数量&nbsp;n&nbsp;和最低支付金额&nbsp;sv。读取每个商品的价格并存储在&nbsp;vector&nbsp;中。调用&nbsp;computePay&nbsp;函数计算最终支付金额。以固定的小数点后两位格式输出最终支付金额。
点赞 评论 收藏
分享
11-18 16:36
兰州大学 Java
点赞 评论 收藏
分享
评论
1
1
分享
牛客网
牛客企业服务