用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - java代码库

猜字符游戏

2017-08-04 作者:举报

[java]代码库

package day06;
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")){
				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]);
			}
		}
		
	}
	
	//生成随机字符数组
	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,表示已存过
		}
		return chs;
	}
	
	//对比:随机字符数组与用户输入的字符数组
	public static int[] check(char[] chs,char[] input){
		int[] result = new int[2]; //对比结果(默认都是0,假设result[1]为字符对个数 

result[0]为位置对个数)
		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;
	}
	
}


分享到:
更多

网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。