用户注册



邮箱:

密码:

用户登录


邮箱:

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

发表随想


还能输入: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、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...