备考蓝桥杯(8)取球博弈 java实现

package pers.robert.lanqiaobeizhenti129;

import java.util.Scanner;

/**
 * 18.取球博弈
今盒子里有n个小球,A、B两人轮流从盒中取球,每个人都可以看到另一个人取了多少个,
也可以看到盒中还剩下多少个,并且两人都很聪明,不会做出错误的判断。
我们约定:
每个人从盒子中取出的球的数目必须是:1,3,7或者8个。
轮到某一方取球时不能弃权!
A先取球,然后双方交替取球,直到取完。
被迫拿到最后一个球的一方为负方(输方)
请编程确定出在双方都不判断失误的情况下,对于特定的初始球数,A是否能赢?
程序运行时,从标准输入获得数据,其格式如下:
先是一个整数n(n<100),表示接下来有n个整数。然后是n个整数,每个占一行(整数<10000),表示初始球数。
程序则输出n行,表示A的输赢情况(输为0,赢为1)。
例如,用户输入:
4
1
2
10
18
则程序应该输出:
0
1
1
0

 * @author Robert
 *
 */
public class The018SelectBallGameDemo1 {
	public static boolean array[]=new boolean[100];
	public static void main(String[] args) {
		array[0]=true;
		for (int i = 1; i <array.length; i++) {
			array[i]=(i>=8&&!array[i-8])||(i>=7&&!array[i-7])||(i>=3&&!array[i-3])||(i>=1&&!array[i-1]);
System.out.println(i+":"+array[i]);
		}
		Scanner scanner=new Scanner(System.in);
		int n=scanner.nextInt();
		int total;
			scanner.nextLine();
			while ((n--)>0) {
			total=scanner.nextInt();
			System.out.println(array[total]?1:0);
		}
	}
}


分析:其实,这里运行完程序之后就可以知道,我们确定完每次可以取多少个球的同时已经确定了初始值为

时最后的结果,

另外的写法1:

public static boolean contest(int n){  
        if(n>=1){  
            switch(n){  
                case 1 : return false;  // 剩1个球,则输   
                case 3 : return false;  // 剩3个球,则输   
                case 7 : return false;  // 剩7个球,则输   
                case 8 : return true;   // 剩8个球,则赢   
                // 如果不是不是1,3,7,8则 选择权交给B,B任然调用该函数,不过返回值需要取反   
                // 而此时A可以选的只有 1 3 7 8 所以用num减去之 逐个测试即可   
                default : return (!contest(n-8)||!contest(n-7)||  
                        !contest(n-3)||!contest(n-1));  
            }  
        }else{  
            return false;  
        }  
    }

另外的写法2:

// 按规则取,还剩下n个球时,先取的人能赢吗?
		static boolean f(int n)
		{
			if(n==1) return false;
			if(n>8)return !f(n-8)||!f(n-7)||!f(n-3)||!f(n-1);
			if(n>7)return !f(n-7)||!f(n-3)||!f(n-1);
			if(n>3)return !f(n-3)||!f(n-1);
			else return !f(n-1);
		}
	


Scanner scan = new Scanner(System.in);  
        int n = scan.nextInt();  
        List<Integer> lis = new ArrayList<Integer>();  
        for(int i=0;i<n;i++){    // 输入数据   
            lis.add(scan.nextInt());  
        }  

经过测试,以上的代码不会产生 sc.nextInt() 后获取字符串那样需要写两个 sc.nextLine()那样的麻烦

这里sc.nextInt()后再获取数字直接添加sc.nextInt()即可

1:false

2:true
3:false
4:true
5:false
6:true
7:false
8:true
9:true
10:true
11:true
12:true
13:true
14:true
15:true
16:false
17:true
18:false
19:true
20:false
21:true
22:false
23:true
24:true
25:true
26:true
27:true
28:true
29:true
30:true
31:false
32:true
33:false
34:true
35:false
36:true
37:false
38:true
39:true
40:true
41:true
42:true
43:true
44:true
45:true
46:false
47:true
48:false
49:true
50:false
51:true
52:false
53:true
54:true
55:true
56:true
57:true
58:true
59:true
60:true
61:false
62:true
63:false
64:true
65:false
66:true
67:false
68:true
69:true
70:true
71:true
72:true
73:true
74:true
75:true
76:false
77:true
78:false
79:true
80:false
81:true
82:false
83:true
84:true
85:true
86:true
87:true
88:true
89:true
90:true
91:false
92:true
93:false
94:true
95:false
96:true
97:false
98:true
99:true
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值