九度 题目1045:百鸡问题

2015-01-24 05:44:53 · 作者: · 浏览: 3
题目描述:

用小于等于n元去买100只鸡,大鸡5元/只,小鸡3元/只,还有1/3元每只的一种小鸡,分别记为x只,y只,z只。编程求解x,y,z所有可能解。

输入:

测试数据有多组,输入n。

输出:

对于每组输入,请输出x,y,z所有可行解,按照x,y,z依次增大的顺序输出。

样例输入:
40
样例输出:
x=0,y=0,z=100
x=0,y=1,z=99
x=0,y=2,z=98
x=1,y=0,z=99
 
          
代码如下,一开始用了三重循环,后来稍微优化了一下,改成了两重循环:
三重循环的代码:
#include 
            
             
int main(){
    int n;
    int x,y,z;
    while(scanf("%d",&n) != EOF){
        x = 0;
        y = 0;
        z = 0;
        int money1 = n;
        for(int i = 0; i <= money1/5; i++){
            x = i;
            int money2 = money1 - 5 * i;
            for(int j = 0; j <= money2/3; j++){
                y = j;
                int money3 = money2 - 3 * j;
                z = 100 - x - y;
                if(z >= 0 && z <= 3 * money3){
                    printf("x=%d,y=%d,z=%d\n");
                }
            }
        }
    }
    return 0;
}

            
两重循环代码:
#include 
            
             
int main(){
     int n;
    int x,y,z;
    while(scanf("%d",&n) != EOF){
        x = 0;
        y = 0;
        z = 0;
        int money1 = n;
        for(int i = 0; i <= money1/5; i++){
            x = i;
            int money2 = money1 - 5 * i;
            for(int j = 0; j <= money2/3; j++){
                y = j;
                int money3 = money2 - 3 * j;
                for(int k = 0; k <= money3 * 3; k++){
                    z = k;
                    if(x+y+z == 100){
                        printf("x=%d,y=%d,z=%d\n",x,y,z);
                    }
                }
            }
        }
    }
    return 0;
}

            
<script type="text/java script">
<script type="text/java script">BAIDU_CLB_fillSlot("771048");
点击复制链接 与好友分享! 回本站首页
<script> function copyToClipBoard(){ var clipBoardContent=document.title + '\r\n' + document.location; clipBoardContent+='\r\n'; window.clipboardData.setData("Text",clipBoardContent); alert("恭喜您!复制成功"); }
<script>window._bd_share_config={"common":{"bdSnsKey":{},"bdText":"","bdMini":"2","bdMiniList":false,"bdPic":"","bdStyle":"0","bdSize":"24"},"share":{}};with(document)0[(getElementsByTagName('head')[0]||body).appendChild(createElement('script')).src='http://bdimg.share.baidu.com/static/api/js/share.js?v=89860593.js?cdnversion='+~(-new Date()/36e5)];
您对本文章有什么意见或着疑问吗?请到 论坛讨论您的关注和建议是我们前行的参考和动力??
上一篇: 大话设计模式C++实现-第9章-原型模式
下一篇: C++ 字符串处理
相关文章
<script type="text/java script">BAIDU_CLB_fillSlot("182716");
<script type="text/java script">BAIDU_CLB_fillSlot("517916");
图文推荐
<iframe src="http://www.2cto.com/uapi.php?tid=362312&catid=339&title=vsW2yCDM4sS/MTA0NaO6sNm8ps7KzOI=&forward=http://www.2cto.com/kf/201412/362312.html" width="100%" height="100%" id="comment_iframe" name="comment_iframe" frameborder="0" scrolling="no">
<script type="text/java script">BAIDU_CLB_fillSlot("771057");