博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
猜字符小游戏编写步骤(基础练习)
阅读量:6789 次
发布时间:2019-06-26

本文共 2124 字,大约阅读时间需要 7 分钟。

package day07;

import java.util.Scanner;
//猜字符小游戏
public class Guessing {
//主方法
  public static void main(String[] args) {
    Scanner scan = new Scanner(System.in);
    char[] chs = generate(); //获取随机字符数组
    System.out.println(chs); //作弊
    int count = 0; //猜错的次数
    while(true) { //自造死循环
      System.out.println("猜吧!");
      String str = scan.next().toUpperCase(); //接收用户输入的字符串
    if(str.equals("EXIT")) { //判断str内容是否是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++; //猜错次数增1
      System.out.println("字符对个数为:"+result[1]+",位置对个数为:"+result[0]);
    }
  }
}
//生成随机字符数组chs
public static char[] generate() {
char[] chs = new char[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]; //开关数组(与letters相对应)
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时,表示对应字符已存过,则重新生成index下标
//当下标index对应的开关为false时,表示对应字符未存过,则循环结束
chs[i] = letters[index]; //基于下标index到letters中获取字符并赋值给chs中的每一个元素
flags[index] = true; //将下标index对应的开关修改为true,表示对应字符已存过
}
//i=0 index=0 chs[0]='A' flags[0]=true
//i=1 index=25 chs[1]='Z' flags[25]=true
//i=2 index=0/25/0/1 chs[2]='B' flags[1]=true

return chs;

}
//对比:随机字符数组chs与用户输入的字符数组input
public static int[] check(char[] chs,char[] input) {
int[] result = new int[2]; //对比结果(0,0)--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; //剩余input元素不再参与本轮比较了
}
}
}
return result;
}
}

 

转载于:https://www.cnblogs.com/ahaijava/p/9965674.html

你可能感兴趣的文章
三年观察揭示TNF抑制剂持续改善强柱患者躯体功能的预测因子
查看>>
数据库练习
查看>>
mongodb的开机自启动
查看>>
1303: [CQOI2009]中位数图
查看>>
1011: [HNOI2008]遥远的行星
查看>>
QTP的那些事--有关一个webtable数据的获取案例
查看>>
20190520
查看>>
《Python 二三事》——python学习必看(转载)
查看>>
Minimum Spanning Tree.prim/kruskal(并查集)
查看>>
北邮14&18年软院机试【参考】答案
查看>>
MySQL查询
查看>>
Linux学习笔记04
查看>>
Unity3d热更新之下载
查看>>
设计模式----备忘录模式
查看>>
如何用chkconfig查看手动输入,跳出循环的四个命令
查看>>
ORM了解知识
查看>>
[NHibernate]ISessionFactory配置
查看>>
jboss服务器修改端口说明
查看>>
个人开发—进度记录(三)
查看>>
Idhttp中get与Post的区别
查看>>