笔试题-牛羊吃草问题
package com.jiucaiyuan.net.question;
/**
 * 牛羊吃草问题:有先吃和有后吃,看谁刚好吃完所有草
 * 吃草规则, 吃的时候只能吃4^m次幂份,看谁会胜利
 *
 * @Author jiucaiyuan  2022/6/22 23:11
 * @mail services@jiucaiyuan.net
 */
public class EatGrass {
    /**
     * 思路1:先手先吃,尝试所有情况,如果能胜利,就先手胜利,否则后手胜利,暴力尝试
     *
     * @param n
     * @return
     */
    public static String winner1(int n) {
        //0   1    2    3     4
        //后  先   后    先    先
        if (n < 5) {
            return (n == 0 || n == 2) ? "后手" : "先手";
        }
        //n>=5
        int base = 1; //先手决定吃的草份数
        //有问题
        while (base <= n) {
            //当一共有n份草,先手吃了base份,留给后手n-base份草
            //父过程是先手,子过程称为后收手
            if (winner1(n - base).equals("后手")) {
                return "先手";
            }
            if (base > n / 4) {  //防止base*4后溢出
                break;
            }
            base *= 4;
        }
        return "后手";
    }
    /**
     * 打表法:通过打印0-100份草的胜利情况:后先后先先后先后先先后先后先先后先后先先后先后先先
     * 分析规律写代码
     *
     * @param n
     * @return
     */
    public static String winner2(int n) {
        if (n % 5 == 0 || n % 5 == 2) {
            return "后手";
        }
        return "先手";
    }
    public static void main(String[] args) {
        for (int i = 0; i < 100; i++) {
            System.out.println(i + "\t" + winner1(i));
        }
    }
}
	
				« scp拷贝文件
				|
				 笔试题-最少的袋子数装苹果»
	
		    
		日历
个人资料
		diaba 寻求合作请留言或联系mail: services@jiucaiyuan.net
链接
最新文章
存档
- 2025年4月(17)
 - 2025年3月(25)
 - 2025年2月(20)
 - 2025年1月(2)
 - 2024年10月(1)
 - 2024年8月(2)
 - 2024年6月(4)
 - 2024年5月(1)
 - 2023年7月(1)
 - 2022年10月(1)
 - 2022年8月(1)
 - 2022年6月(11)
 - 2022年5月(6)
 - 2022年4月(33)
 - 2022年3月(26)
 - 2021年3月(1)
 - 2020年9月(2)
 - 2018年8月(1)
 - 2018年3月(1)
 - 2017年3月(3)
 - 2017年2月(6)
 - 2016年12月(3)
 - 2016年11月(2)
 - 2016年10月(1)
 - 2016年9月(3)
 - 2016年8月(4)
 - 2016年7月(3)
 - 2016年6月(4)
 - 2016年5月(7)
 - 2016年4月(9)
 - 2016年3月(4)
 - 2016年2月(5)
 - 2016年1月(17)
 - 2015年12月(15)
 - 2015年11月(11)
 - 2015年10月(6)
 - 2015年9月(11)
 - 2015年8月(8)
 
分类
热门文章
- SpringMVC:Null ModelAndView returned to DispatcherServlet with name 'applicationContext': assuming HandlerAdapter completed request handling
 - Mac-删除卸载GlobalProtect
 - java.lang.SecurityException: JCE cannot authenticate the provider BC
 - MyBatis-Improper inline parameter map format. Should be: #{propName,attr1=val1,attr2=val2}
 - Idea之支持lombok编译
 
标签
最新评论
- logisqykyk	
Javassist分析、编辑和创建jav... - xxedgtb	
Redis—常见参数配置 - 韭菜园 ... - wdgpjxydo	
SpringMVC:Null Model... - rllzzwocp	
Mysql存储引擎MyISAM和Inno... - dpkgmbfjh	
SpringMVC:Null Model... - tzklbzpj	
SpringMVC:Null Model... - bqwrhszmo	
MyBatis-Improper inl... - 乐谱吧	
good非常好 - diaba	
@diaba:应该说是“时间的度量依据”... - diaba	
如果速度增加接近光速、等于光速、甚至大于... 
最新微语
- 在每件事情上花费的东西,就是生命的一部分,而我们花费的这些东西要求立即得到回报,或者在一个长时间以后得到回报。
2025-01-23 15:46
 - 诺曼·文森特说:“并不是你认为自己是什么样的人,你就是什么样的人。但是你的思想是什么样,你就是什么样的人。”
2025-01-23 15:44
 - 从今天起,做一个幸福的人。喂马,砍柴,(思想)周游世界
2022-03-21 23:31
 - 2022.03.02 23:37:59
2022-03-02 23:38
 - 几近崩溃后,找到解决方法,总是那么豁然开朗!所以遇到问题要坚持!
2018-07-18 10:49
 

发表评论: