java算法 第七屆 藍橋杯B組(題+答案) 9.取球博弈


 

9.取球博弈  (程序設計)

兩個人玩取球的游戲。
一共有N個球,每人輪流取球,每次可取集合{n1,n2,n3}中的任何一個數目。
如果無法繼續取球,則游戲結束。
此時,持有奇數個球的一方獲勝。
如果兩人都是奇數,則為平局。

假設雙方都采用最聰明的取法,
第一個取球的人一定能贏嗎?
試編程解決這個問題。

輸入格式:
第一行3個正整數n1 n2 n3,空格分開,表示每次可取的數目 (0<n1,n2,n3<100)
第二行5個正整數x1 x2 ... x5,空格分開,表示5局的初始球數(0<xi<1000)

輸出格式:
一行5個字符,空格分開。分別表示每局先取球的人能否獲勝。
能獲勝則輸出+,
次之,如有辦法逼平對手,輸出0,
無論如何都會輸,則輸出-

例如,輸入:
1 2 3
1 2 3 4 5

程序應該輸出:
+ 0 + 0 -

再例如,輸入:
1 4 5
10 11 12 13 15

程序應該輸出:
0 - 0 + +

再例如,輸入:
2 3 5
7 8 9 10 11

程序應該輸出:
+ 0 0 0 0

資源約定:
峰值內存消耗(含虛擬機) < 256M
CPU消耗  < 3000ms

 1 import java.util.Scanner;
 2 
 3 public class _9取球博弈 {
 4      public static int [] n = new int[3];  
 5         public static int [] init = new int[5];  
 6         public static int [] end = new int[1000];  
 7         public static char [] sign = {'-','0','0','+'};  
 8         public static void main(String [] args){  
 9             Scanner scan = new Scanner(System.in);  
10             for(int i = 0; i < 3; i++){  
11                 n[i] = scan.nextInt();  
12             }  
13             int Min = Math.min(n[0], Math.min(n[1], n[2]));  
14             for(int i = 0; i < 5; i++){  
15                 init[i] = scan.nextInt();  
16             }  
17             for(int i = 0; i < Min; i++){  
18                 end[i] = 2;  
19             }  
20             for(int i = Min; i < end.length; i++){  
21                 int temp = 0;  
22                 for(int j =0; j < 3; j++){  
23                     if(i - n[j] < 0)  
24                         continue;  
25                     else if(end[i-n[j]] == 3){  
26                         if(n[j]%2 != 0)  
27                             temp = 1 > temp ? 1 : temp;  
28                     }  
29                     else if(end[i-n[j]] == 0){  
30                         if(n[j]%2 == 0)  
31                             temp = 3;  
32                         else  
33                             temp = 2 > temp ? 2 : temp;  
34                     }  
35                     else if(end[i-n[j]] == 2){  
36                         if(n[j]%2==0)  
37                             temp = 2 > temp ? 2 : temp;  
38                         else  
39                             temp = 3;  
40                     }  
41                     else if(end[i-n[j]] == 1){  
42                         if(n[j]%2==0)  
43                             temp = 1 > temp ? 1 : temp;  
44                     }  
45                 }  
46                 end[i] = temp;  
47             }  
48             for(int i = 0; i < 5; i++){  
49                 System.out.print(sign[end[init[i]]]+" ");  
50             }  
51         }  
52 }

(參考網上的,沒有思路0.0)


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM