现在,对于 Java 课程,我正在尝试构建一个类似于 Mastermind 的游戏。在这个游戏中,生成一个 4 位随机数,用户尝试猜测该数字。每次猜测时,计算机都会说明有多少正确的数字按正确的顺序排列,有多少正确的数字按错误的顺序排列。
出于某种原因,一切都取决于我对该程序的二进制搜索,这实际上是该程序的核心。我花了几个小时来调整它,但我仍然无法得到它。有任何想法吗?
在这个例子中,我试图猜测 9935,但我意识到这不是一个随机数。
非常感谢!
编辑:当我运行这个程序并使用猜测“9875”时,它并没有给我正确的结果。
我需要找到的猜测和结果是:
请输入四位数字:9874
正确但位置错误的位数:0
正确位置的正确位数:1
请输入四位数字:9899
正确但位置错误的位数:1
正确位置的正确位数:1
请输入四位数字:9593
正确但位置错误的位数:3
正确位置的正确位数:1
请输入四位数字:9935
正确但位置错误的位数:0
正确位置的正确位数:4
你是对的!
public class Mastermind {
public static void main(String[] args) {
Random randomGenerator = new Random();
Scanner input = new Scanner(System.in);
int randomNumber = 9935;
int[] randomArray = new int[4];
int temp = randomNumber;
for (int i = 3; i >= 0; i--){
int n = temp%10;
randomArray[i] = n;
temp /= 10;
}
boolean found = false;
while (found == false){
System.out.print(Arrays.toString(randomArray));
int[] guessArray = new int[4];
System.out.print("Please enter a four-digit number: ");
int guessTemp = input.nextInt();
for (int i = 3; i >= 0; i--){
int n = guessTemp%10;
guessArray[i] = n;
guessTemp /= 10;
}
if (Arrays.equals(randomArray, guessArray)){
System.out.println("You are correct!");
found = true;
} else {
int numberRightRight = 0;
int numberRightWrong = 0;
int indexFound = 0;
for(int i = 0; i < guessArray.length; i ++){
System.out.println(randomArray[i]);
indexFound = Arrays.binarySearch(guessArray, randomArray[i]);
System.out.println(indexFound);
if (indexFound >= 0){
if(indexFound == i){
numberRightRight++;
} else {
numberRightWrong++;
}
}
}
System.out.println("The number of correct digits but in the wrong place: " + numberRightWrong);
System.out.println("The number of correct digits in the right place: " + numberRightRight);
}
}
}