Java-锤子剪刀布 (20)

本文介绍了一个简单的程序,用于统计锤子剪刀布游戏中两名玩家的胜负和平局次数,并找出各自获胜次数最多的手势。通过读取输入手势记录,程序能够准确地计算并输出结果。

题目描述

大家应该都会玩“锤子剪刀布”的游戏:

现给出两人的交锋记录,请统计双方的胜、平、负次数,并且给出双方分别出什么手势的胜算最大。

输入描述:

输入第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;
	}
}


评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值