要求:生成随机五个字符,接收键盘输入进行比较(字符以及位置都要对),猜对一个字符100分,猜错扣10分,
输入exit退出
1.设计数据结构:变量
1)char[] chs; //随机字符数组
2)char[] input; //用户输入的字符数组
3)int[] result; //对比的结果
4)int score; //得分
2.设计程序结构:方法
1)主方法:
public static void main(String[] args){
//…
}
2)生成随机字符数组chs:
public static char[] generate(){
char[] chs = new char[5];
//…
return chs;
}
3)对比:随机字符数组chs与用户输入的字符数组input
public static int[] check(char[] chs,char[] input){
int[] result = new int[2];
//…
return result;
}
3.设计算法:方法体
String str = “abcde”;
1)将字符串str转换为字符数组
char[] cs = str.toCharArray();
2)将字符串str转换为大写字母
str = str.toUpperCase();
将字符串str转换为小写字母
str = str.toLowerCase();
3)判断字符串内容相等
if(str.equals(“EXIT”)){
}
代码:
public class GussingDemo {
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
int count = 0;//存储猜错的次数
char chs[] =getChar();//生成一个长度为5的随机字符数组
System.out.println(chs);
System.out.println("欢迎来到猜字符游戏!");
while(true){//自造死循环
System.out.println("猜吧!");
String str = scan.next().toUpperCase();//将输入的字符都转换成大写
char input[] = str.toCharArray();//将字符串转换成字符数组
if(str.equals("EXIT")){//输入exit则跳出循环退出
System.out.println("下次再来吧!");
break;
}
int result[] = chack(chs,input);
if (result[1]==chs.length) {
int score = 100*chs.length-10*count;//猜对一个100分,猜错一次扣10分
System.out.println("恭喜你猜对了!分数为:"+score);
break;//猜对就跳出循环
}else{
count++;//猜错次数+1
System.out.println("猜对字符"+result[0]+"个,位置猜对"+result[1]+"个");
}
}
}
public static char[] getChar(){//生成一个随机字符数组方法
char[] chs = new char[5];//定义一个五个字符的char数组
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'};//创建一个包含26个字母的字符数组
boolean [] flags = new boolean[letters.length];//创建一个开关数组来获取某个字母是否被创建
for (int i = 0; i < chs.length; i++) {
int index;
do{
index = (int)(Math.random()*26);//生成一个0~26(不包括26)的随机数,对应letters的下标
}while(flags[index]==true);//判断该字符是否使用过
chs[i] = letters[index];
flags[index]= true;//如果该字母已被获取,将对应下标的flags数组元素改为true
}
return chs;
}
public static int[] chack(char[] chs,char[] input){//比较生成的随机数组chs和用户输入的数组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[0]++;
if(i==j){//位置对
result[1]++;
}
break;//因为字符是不重复的,所以有匹配到的字符就可以跳出循环;
}
}
}
return result;
}
}