Acm - 百钱买百鸡问题

1.问题描述

“百钱买百鸡”是我国古代的著名数学题。题目这样描述:
3 文 钱可以买1只公鸡,
2 文钱可以买一只母鸡,
1 文钱可以买3 只小鸡。
用100 文 钱买100 只鸡,那么各有公鸡、母鸡、小鸡多少只?

2.分析

(1)从公鸡和母鸡下手
鸡: 公 (x) , 母(y) 小 (100-x-y )
钱: 3x+2y+(100-x-y)/3=100

可以得出公鸡和母鸡的关系 : 8x+5y=200

(2)确定 公鸡和母鸡的范围
没有公鸡 : x=0 y=40 小=60
没有母鸡: x=25 y=0 小=75
公鸡最大值为 25 ,母鸡最大值 40 ,故 :
0<=x<=25 , 0<=y<=40

3.算法实现

(1)单个循环

        for (int x = 0; x <= 25; x++) {
            // 0<=公鸡只<=25
            if ((200 - 8 * x) % 5 == 0) {
                int y = (200 - 8 * x) / 5;
                System.out.println("公鸡 :" + x + "只 ,母鸡 :" + y + " 只 ,小鸡 :"
                        + (100 - x - y) + " 只");
            }
        }

(2)双循环

for (int x = 0; x <= 25; x++) {

            for(int y=0;y<=40;y++){
                if(8*x+5*y==200){
                    System.out.println("公鸡 :" + x + "只 ,母鸡 :" + y + " 只 ,小鸡 :"
                            + (100 - x - y) + " 只");
                }
            }
 }

结果 :

公鸡 :0只 ,母鸡 :40 只 ,小鸡 :60 只
公鸡 :5只 ,母鸡 :32 只 ,小鸡 :63 只
公鸡 :10只 ,母鸡 :24 只 ,小鸡 :66 只
公鸡 :15只 ,母鸡 :16 只 ,小鸡 :69 只
公鸡 :20只 ,母鸡 :8 只 ,小鸡 :72 只
公鸡 :25只 ,母鸡 :0 只 ,小鸡 :75 只
-----------------------------------------------

(3)测试其他结果
假如有 x=4 只公鸡 ,那么有 在确定的 母鸡 (0<=y<=40)范围内找满足100文买100只鸡的条件 ,判断是否还有其他情况存在 ?

 for(int y=0;y<=40;y++){
                  if((88-2*y)%3==0){
                      int xiaojizhi=(88-2*y)/3;
                      if(4+y+xiaojizhi==100){
                      System.out.println("钱 :88 ;母鸡 :"+y);
                      }else{
                          System.out.println("no man zu");
                      }
                  }
        }

结果 : no man zu

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明 YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明YOLO高分设计资源源码,详情请查看资源内容中使用说明
ACM-ICPC(国际大学生程序设计竞赛)是一项面向大学生的计算机编程竞赛,涉及算法和数据结构等领域。在比赛中,选手需要解决一系列编程问题,使用合适的算法和数据结构来实现正确和高效的解决方案。 对于整理ACM-ICPC模板,以下是一些建议: 1. 了解比赛要求:首先,你需要了解ACM-ICPC比赛的具体要求和规则。这包括了解比赛所涉及的算法和数据结构,以及题目的类型和难度等。 2. 收集资料:收集与ACM-ICPC相关的资料,包括经典算法和数据结构的实现代码、常见问题的解题思路等。可以参考教材、博客、论文等资源。 3. 整理模板:将收集到的资料整理成模板。可以按照算法和数据结构的分类进行整理,例如排序算法、图算法、字符串算法等。对每个模板,添加必要的注释和示例代码,以便理解和使用。 4. 测试代码:对每个模板编写测试代码,确保它们的正确性和可靠性。可以使用已知的测试用例或自行设计测试用例。 5. 更新与扩充:定期更新和扩充模板,以适应ACM-ICPC比赛中新出现的算法和数据结构。同时,根据自己的经验和理解,对模板进行优化和改进。 6. 练习和复习:在比赛之前,利用整理好的模板进行练习和复习。尝试解决一些经典问题,使用模板中的算法和数据结构进行实现,并进行优化。 希望这些建议对你整理ACM-ICPC模板有所帮助!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值