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)