您的位置:首页 > 编程语言 > Java开发

JavaSE控制台版猜字母游戏

2017-05-02 17:09 211 查看
游戏规则:(实现效果)

猜字母游戏,其游戏规则为:程序随机产生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;
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息