JavaSE控制台版猜字母游戏

游戏规则:(实现效果)

猜字母游戏,其游戏规则为:程序随机产生5个按照一定顺序排列的字符作为猜测的结果,由玩家来猜测此字符串。玩家可以猜测多次,每猜测一次,则由系统提示结果。如果猜测的完全正确,则游戏结束,计算玩家的游戏得分并输出;如果没有猜对,则提示猜测的结果,如猜对了几个字符,以及猜对了几个字符的位置等信息,并提示玩家游戏继续。本题要求使用交互的方式实现此游戏:由玩家在控制台输入所猜测的字符串,如果所猜测的字符串与结果并不完全相同,则在界面输出比较后的结果,并提醒玩家继续猜测。每次猜测后,程序将比较玩家所输入的字符串,比较字符以及字符的位置,然后提示结果:5个字符中正确的字符个数,以及位置正确的字符个数,以便于玩家判断后续如何进行猜测。玩家终于猜测正确后,游戏结束,并给出游戏得分,其中,游戏的得分规则为:字符的个数乘以100为总分,即此游戏的总分为 500 分。玩家如果第一次就猜对,则得满分(500分);每多猜测一次,则扣10分。由图-8可以看出,玩家共猜测了5次,因此,得分为 450。最后,如果玩家在控制台录入 exit,则游戏中止,程序结束。

代码实现:

Scanner sca = new Scanner(System.in);
		int count = 0;// 猜错的次数
		char[] chs = generate();// 获取随机生成的随机字符
		System.out.println(chs);// 作弊
		while (true) {// 制造死循环
			System.out.println("猜吧!");
			String str = sca.next().toUpperCase();// 将获取的输入字符串转化为大写
			if (str.equals("EXIT")) {// 判断是否退出
				System.out.println("下次再来!");
				break;
			}
			char[] input = str.toCharArray();// 讲字符串转换为字符数组
			// 与随机生成字符做比较
			int[] result = check(chs, input);
			if (result[0] == chs.length) {// 猜对了
				int score = 100 * chs.length - 10 * count;// 一个字符100分,猜错一次扣10分
				System.out.println("恭喜你,猜对了,得分:" + score);
				break;
			} else {// 猜错了
				count++;
				System.out.println("字符对:" + result[1] + "位置对:" + result[0]);
			}
		}
	}

	// 生成随机字符的游戏
	public static char[] generate() {
		char[] chs = new char[5];// 定义5个字符的数组
		char[] letters = { 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J',
				'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V',
				'W', 'X', 'Y', 'Z' };// 字符数组的字符范围
		boolean[] flags = new boolean[letters.length];// 对应的开关数组,默认为false
		// 遍历随机字符数组
		for (int i = 0; i < chs.length; i++) {
			int index;
			do {
				index = (int) (Math.random() * letters.length);// 下标0-25
			} while (flags[index] == true);
			// 如果index对应的开关为true,表示已经存过;如果为false,内循环结束
			chs[i] = letters[index];// 基于index,从letters中取元素赋值到chs数组
			flags[index] = true;// 表示已经存过
		}
		return chs;

	}

	// 做对比的方法,比较需要参数,一个是生成的,一个是输入的
	public static int[] check(char[] chs, char[] input) {
		int[] result = new int[2];// 保存结果。result[0]:位置对 result[1]:字符对
		for (int i = 0; i < chs.length; i++) {// 遍历随机数组
			for (int j = 0; j < input.length; j++) {// 遍历用户输入的数组
				if (chs[i] == input[j]) {// 字符对
					result[1]++;// 字符对,字符个数增1
					if (i == j) {
						result[0]++;// 位置对,位置个数增1
					}
					break;// 后面的元素就不用比较了
				}
			}
		}
		return result;


  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值