Поэтому, пытаясь создать генератор случайных чисел, который предлагал бы пользователю угадывать сгенерированное число до тех пор, пока он не угадает его, я столкнулся с некоторыми проблемами.
Все работало нормально, пока я не попытался добавить возможность снова играть. Проблема в том, что если они угадывают неправильное число, оно продолжает бесконечно повторять одно и то же сообщение об ошибке, независимо от того, угадали ли они слишком много, слишком мало или это был неверный ввод, постоянно. Если номер угадан с первого раза, все работает нормально, предлагает повторить игру и работает отлично.
Дело в том, что я использовал 2 цикла for, потому что, когда они начинают угадывать, я не хочу:
«Эта программа будет генерировать случайное число от 0 до 100, которое вы должны угадать».
Чтобы выводился каждый раз, когда они угадывают неправильный ответ, я хочу, чтобы он выводился только тогда, когда они выбрали вариант воспроизведения снова, поэтому я сделал вложенный цикл for. Но проблема остается в том, что внутренний цикл for переходит в бесконечный цикл после первого неверного предположения, отображающего тот же ответ.
import javax.swing.JOptionPane;
import java.util.Random;
import javax.swing.UIManager;
import java.awt.*;
public class RandomNumberGuesser{
public static void main(String[] args){
UIManager m1=new UIManager();
Color g = Color.gray;
Color lg = g.brighter();
m1.put("OptionPane.background", lg);
m1.put("Panel.background", lg);
int x;
for(x = 1; true; x++){
Random random = new Random();
int randomNumber = random.nextInt(100);
System.out.println(randomNumber);
JOptionPane.showMessageDialog(null,
"This program will generate a random number from 0 to 100 which you have to guess.",
"Number Guesser",
JOptionPane.INFORMATION_MESSAGE);
String guess = JOptionPane.showInputDialog(null,
"Guess a number.",
"Guess",
JOptionPane.QUESTION_MESSAGE);
if(guess == null){
System.out.println("The user has terminated the program");
System.exit(0);
}
int guess1 = Integer.parseInt(guess);
int y;
for(y = 1; true; y++){
if(guess1 > 100 || guess1 < 0)
JOptionPane.showMessageDialog(null,
"Guess is out of range!\nPlease enter valid input.",
"Invalid Input",
JOptionPane.WARNING_MESSAGE);
else if(randomNumber > guess1)
JOptionPane.showMessageDialog(null,
"You guessed too low.\nGuess again!",
"Your guess",
JOptionPane.INFORMATION_MESSAGE);
else if(randomNumber < guess1)
JOptionPane.showMessageDialog(null,
"You guessed too high.\nGuess again!",
"Your guess",
JOptionPane.INFORMATION_MESSAGE);
else{
JOptionPane.showMessageDialog(null,
"You guessed the number right!\nIt took you "+y+" attempt(s) to guess it.",
"Congratulations!",
JOptionPane.INFORMATION_MESSAGE);
if (JOptionPane.showConfirmDialog(null, "Want to play again?", "Play again?",
JOptionPane.YES_NO_OPTION) == JOptionPane.NO_OPTION) {
System.out.println("Play again soon!");
System.exit(0);
}
else{
y = 0;
break;
}
}
}
}
}
}
for(x = 1; true; x++){
заставляет меня плакать, используйтеwhile
для таких вещей. Если вы хотите выйти, просто присвойте некоторой переменной значение, чтобы внешний цикл знал, что он тоже долженbreak
(есть лучшие способы, но я думаю, что лучше начинать медленно). - person SJuan76   schedule 28.10.2013