题目描述
大家应该都会玩“锤子剪刀布”的游戏: 现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。
输入描述:
输入第1行给出正整数N(<=105),即双方交锋的次数。随后N行,每行给出一次交锋的信息,即甲、乙双方同时给出的的手势。C代表“锤子”、J代表“剪刀”、B代表“布”,第1个字母代表甲方,第2个代表乙方,中间有1个空格。
输出描述:
输出第1、2行分别给出甲、乙的胜、平、负次数,数字间以1个空格分隔。第3行给出两个字母,分别代表甲、乙获胜次数最多的手势,中间有1个空格。如果解不唯一,则输出按字母序最小的解。
输入例子:
10 C J J B C B B B B C C C C B J B B C J J
输出例子:
5 3 2 2 3 5 B B
import java.util.Scanner; /* * 枚举类型,存放B,C,J三种手势; * 自定义方法:1.将手势字符转换为下标;2.将下标数字转换为手势字符; */ enum EnumTest{ B, C, J; public static int convert(char c){ switch (c) { case 'B': return 0; case 'C': return 1; case 'J': return 2; default: break; } return c; } public static char convert2(int i){ switch (i) { case 0: return 'B'; case 1: return 'C'; case 2: return 'J'; default: break; } return 0; } } public class Main { public static void main(String[] args) { Scanner in = new Scanner(System.in); int N = in.nextInt(); //A、B玩家以B(布)、C(锤子)、J(剪刀)赢的次数 int[] AWin = new int[3]; int[] BWin = new int[3]; int countDraw = 0;//平局次数 /* * 输入手势字符,转换成数字下标,判断输赢,并增加对应玩家出特定手势的次数; */ for (int i = 0; i < N; i++) { int a = EnumTest.convert(in.next().charAt(0)); int b = EnumTest.convert(in.next().charAt(0)); //手势相同,增加平局次数 if (a == b) { countDraw++; }else{ boolean win = compare(a, b); if (win) { AWin[a]++; }else{ BWin[b]++; } } } in.close(); int countA = AWin[0]+AWin[1]+AWin[2]; //打印A、B赢、平局、输的次数,并打印A、B获胜最多的手势 System.out.println(countA+" "+countDraw+" "+(N-countA-countDraw)); System.out.println((N-countA-countDraw)+" "+countDraw+" "+countA); System.out.println(EnumTest.convert2(max(AWin))+" "+EnumTest.convert2(max(BWin))); } //判断A、B输赢 public static boolean compare(int c1, int c2){ if ((c1 == 0 && c2 == 1) || (c1 == 1 && c2 == 2) || (c1 == 2 && c2 == 0)) { return true; } return false; } //判断玩家获胜时采用最多的手势 public static int max(int[] array){ int max = array[0]; for (int i = 0; i < array.length; i++) { if (max < array[i]) { max = array[i]; } } for (int i = 0; i < array.length; i++) { if(array[i] == max){ return i; } } return 0; } }
本文介绍了一个简单的程序,用于统计锤子剪刀布游戏中两名玩家的胜负和平局次数,并找出各自获胜次数最多的手势。通过读取输入手势记录,程序能够准确地计算并输出结果。
445

被折叠的 条评论
为什么被折叠?



