java實(shí)現(xiàn)簡(jiǎn)單的猜數(shù)字小游戲
本文實(shí)例為大家分享了java實(shí)現(xiàn)簡(jiǎn)單的猜數(shù)字的具體代碼,供大家參考,具體內(nèi)容如下
題目描述:
猜數(shù)字(又稱 Bulls and Cows )是一種古老的的密碼破譯類益智類小游戲,起源于20世紀(jì)中期,一般由兩個(gè)人或多人玩,也可以由一個(gè)人和電腦玩。通常由兩個(gè)人玩,一方出數(shù)字,一方猜。出數(shù)字的人要想好一個(gè)沒(méi)有重復(fù)數(shù)字的4個(gè)數(shù),不能讓猜的人知道。猜的人就可以開(kāi)始猜。每猜一個(gè)數(shù)字,出數(shù)者就要根據(jù)這個(gè)數(shù)字給出nAmB,其中A前面的數(shù)字n表示數(shù)字正確且位置也正確的數(shù)的個(gè)數(shù),而B(niǎo)前的數(shù)字m表示數(shù)字正確但位置不正確的數(shù)的個(gè)數(shù)。如正確答案為 5234,而猜的人猜 5346,則是 1A2B,其中有一個(gè)5的位置對(duì)了,記為1A,而3和4這兩個(gè)數(shù)字對(duì)了,而位置沒(méi)對(duì),因此記為 2B,合起來(lái)就是 1A2B。接著猜的人再根據(jù)出題者的幾A幾B繼續(xù)猜,直到猜中(即 4A0B)為止。
程序要求:
1、滿足題意 2、輸入數(shù)字的合法性3、輸出總猜測(cè)次數(shù)
代碼
package Practice;
// 猜數(shù)字 (Bulls and cows)
import java.util.Scanner;
public class Day0322 {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
// 產(chǎn)生0000~9999的隨機(jī)數(shù)
double r = Math.random();
int res = (int)(r * 8999 + 1000);
int flag = 0;
// 合法性檢查,判斷存在重復(fù)數(shù)字
while(flag == 0)
{
int[] check = new int[10];
for(int i = 0; i < 10; i ++ ) check[i] = 0;
check[res / 1000] += 1;check[(res / 100) % 10] += 1;
check[(res / 10) % 10] += 1;check[res % 10] += 1;
for(int i = 0; i < 10; i ++ )
if(check[i] >= 2) {
r = Math.random();
res = (int)(r * 8999 + 1000);
flag = 0;
break;
}
else flag = 1;
}
// 0000~9999
System.out.println("答案: " + res);
int input = -1;
int idx = 0;
int times = 0;
while(input != res)
{
System.out.print("請(qǐng)輸入你猜的數(shù)字: ");
input = scanner.nextInt();
int inputcopy = input;
if(input < 0)
{
System.out.println("您輸入的數(shù)字不是四位數(shù)!");
times ++;
continue;
}
int t = 0;
// 輸入數(shù)字為4位數(shù),合法性檢查
while(inputcopy != 0)
{
inputcopy /= 10;
t ++;
}
if(t != 4)
{
System.out.println("您輸入的數(shù)字不是四位數(shù)!");
times ++;
continue;
}
int n = 0, m = 0;// nAmB
if(input == res) break;
// 輸入的各個(gè)位數(shù)
int[] a = new int[4];
a[0] = input / 1000;a[1] = (input / 100) % 10;
a[2] = (input / 10) % 10; a[3] = (input) % 10;
// 答案的各個(gè)位數(shù)
int[] ans = new int[4];
ans[0] = res / 1000;ans[1] = (res / 100) % 10;
ans[2] = (res / 10) % 10; ans[3] = (res) % 10;
for(int i = 0; i < 4; i ++)
{
if(ans[i] == a[i]) n += 1; // A的數(shù)量
for(int j = 0; j < 4; j ++){// B的數(shù)量
if(ans[j] == a[i] && j != i) m += 1;
}
}
System.out.print((++ idx) + ": " + n + "A" + m + "B");
System.out.println();
times ++;
}
if(input == res){
times ++;
System.out.println("4A0B");
System.out.println("你很厲害啊!");
System.out.println("猜測(cè)次數(shù): " + times);
}
}
}
運(yùn)行效果

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Spring Boot2.0中SpringWebContext找不到無(wú)法使用的解決方法
這篇文章主要給大家介紹了關(guān)于Spring Boot2.0中SpringWebContext找不到無(wú)法使用的解決方法,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-12-12
Mybatis配置之<properties>屬性配置元素解析
這篇文章主要介紹了Mybatis配置之<properties>屬性配置元素解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
JDK21中虛擬線程到底是什么以及用法總結(jié)(看完便知)
這篇文章主要給大家介紹了關(guān)于JDK21中虛擬線程到底是什么以及用法的相關(guān)資料,虛擬線程是一種輕量化的線程封裝,由jvm直接調(diào)度和管理,反之普通的線程其實(shí)是調(diào)用的操作系統(tǒng)的能力,對(duì)應(yīng)的是操作系統(tǒng)級(jí)的線程,需要的朋友可以參考下2023-12-12
Java中sleep()與wait()的區(qū)別總結(jié)
因?yàn)樽罱鼘W(xué)習(xí)時(shí)正好碰到這兩個(gè)方法,就查閱相關(guān)資料,并通過(guò)程序?qū)崿F(xiàn),進(jìn)行區(qū)別總結(jié)一下,所以下面這篇文章主要給大家總結(jié)介紹了關(guān)于Java中sleep()與wait()區(qū)別的相關(guān)資料,需要的朋友可以參考,下面來(lái)一起看看吧。2017-05-05
零基礎(chǔ)寫Java知乎爬蟲(chóng)之將抓取的內(nèi)容存儲(chǔ)到本地
上一回我們說(shuō)到了如何把知乎的某些內(nèi)容爬取出來(lái),那么這一回我們就說(shuō)說(shuō)怎么把這些內(nèi)容存儲(chǔ)到本地吧。2014-11-11
java對(duì)接支付寶支付接口簡(jiǎn)單步驟記錄
最近項(xiàng)目APP需要接入微信、支付寶支付功能,在分配開(kāi)發(fā)任務(wù)時(shí),聽(tīng)說(shuō)微信支付接口比支付寶支付接口要難實(shí)現(xiàn),這篇文章主要給大家介紹了關(guān)于java對(duì)接支付寶支付接口的簡(jiǎn)單步驟,需要的朋友可以參考下2024-05-05
Java中I/O流讀取數(shù)據(jù)不完整的問(wèn)題解決
本文主要介紹了ava中I/O流讀取數(shù)據(jù)不完整的問(wèn)題,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05

