Java實(shí)現(xiàn)猜字小游戲
猜字游戲是一款益智游戲,喜歡玩具有挑戰(zhàn)性單詞游戲的你就可以來體驗(yàn)一下了,給你一個字母板。嘗試通過想象相鄰字母的單詞。您將獲得一個分?jǐn)?shù),根據(jù)您使用的字母,你已經(jīng)使用了多少個字母,并以這些字母相關(guān)聯(lián)的任何修飾符都可以的。
具體代碼如下所示:
package test07;
import java.util.Scanner;
//猜字符游戲
public class Guessing {
//主方法
public static void main(String[] args) {
Scanner scan = new Scanner(System.in);
char[] chs = generate(); //獲取隨機(jī)字符數(shù)組
System.out.println(chs); //作弊
int count = 0; //猜錯的次數(shù)
while(true){ //自造死循環(huán)
System.out.println("猜吧!");
String str = scan.nextLine().toUpperCase(); //接收用戶輸入的字符串并轉(zhuǎn)換為大寫字母
if(str.equals("EXIT")) { //判斷字符串內(nèi)容是否是EXIT
System.out.println("下次再來吧!");
break;
}
char[] input = str.toCharArray(); //將字符串轉(zhuǎn)換為字符數(shù)組
int[] result = check(chs,input); //對比:隨機(jī)字符數(shù)組與用戶輸入的字符數(shù)組
if(result[0]==chs.length) { //對
int score = 100*chs.length-10*count; //1個字符100分,猜錯一次扣10分
System.out.println("恭喜你猜對了,得分為:"+score);
break;
}else { //錯
count++; //猜錯次數(shù)增1
System.out.println("字符對個數(shù)為:"+result[1]+",位置對個數(shù)為:"+result[0]);
}
}
}
//生成隨機(jī)字符數(shù)組chs
public static char[] generate() {
char[] chs = new char[5]; //隨機(jī)字符數(shù)組
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' }; //隨機(jī)字符范圍數(shù)組
boolean[] flags = new boolean[letters.length]; //標(biāo)記數(shù)組
for(int i=0;i<chs.length;i++) { //遍歷隨機(jī)字符數(shù)組
int index;
do {
index = (int)(Math.random()*letters.length); //隨機(jī)下標(biāo)(0到25之間)
}while(flags[index]==true); //下標(biāo)index對應(yīng)的標(biāo)記為true,表示對應(yīng)字符已經(jīng)使用過,則重新生成index下標(biāo)
//下標(biāo)index對應(yīng)的標(biāo)記為false時,表示對應(yīng)字符未用過,則循環(huán)結(jié)束
chs[i] = letters[index]; //基于下標(biāo)index獲取對應(yīng)的字符并賦值給chs中的每一個元素
flags[index] = true; //將下標(biāo)index對應(yīng)的標(biāo)記修改為true,表示對應(yīng)字符已存過
}
return chs;
/*
* 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
* ...
*/
}
//對比:隨機(jī)字符數(shù)組chs與用戶輸入的字符數(shù)組input
public static int[] check(char[] chs,char[] input) {
int[] result = new int[2]; //對比結(jié)果(0,0)--假設(shè)result[1]為字符對,result[0]為位置對
for(int i=0;i<chs.length;i++) { //遍歷隨機(jī)字符數(shù)組
for(int j=0;j<input.length;j++) { //遍歷用戶輸入的字符數(shù)組
if(chs[i]==input[j]) { //字符對
result[1]++; //字符對個數(shù)增1
if(i==j) { //位置對
result[0]++; //位置對個數(shù)增1
}
break; //剩余input元素不再參與比較了
}
}
}
return result;
}
}
總結(jié)
以上所述是小編給大家介紹的Java實(shí)現(xiàn)猜字小游戲,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
解決idea2020.2遇到pom.xml文件報錯maven插件tomcat7的問題
這篇文章主要介紹了idea2020.2遇到pom.xml文件報錯maven插件tomcat7的問題,本文給大家分享解決方法,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09
SpringBoot項(xiàng)目中連接SQL Server的三種方式
連接SQL Server是許多Spring Boot項(xiàng)目中常見的需求之一,本文主要介紹了SpringBoot項(xiàng)目中連接SQL Server的三種方式,具有一定的參考價值 ,感興趣的可以了解一下2023-09-09
使用OpenFeign實(shí)現(xiàn)服務(wù)調(diào)用的方法詳解
OpenFeign是運(yùn)行在客戶端的聲明式服務(wù)調(diào)用的框架,通過聲明接口的方式來達(dá)到對服務(wù)的調(diào)用,本文就來和大家講講如何使用OpenFeign實(shí)現(xiàn)服務(wù)調(diào)用吧2023-06-06
剖析Java中在Collection集合中使用contains和remove為什么要重寫equals
這篇文章主要介紹了Collection集合的contains和remove方法詳解remove以及相關(guān)的經(jīng)驗(yàn)技巧,通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
解析java.library.path和LD_LIBRARY_PATH的介紹與區(qū)別
這篇文章主要介紹了java.library.path和LD_LIBRARY_PATH的介紹與區(qū)別,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-05-05

