Метод в Java-программе не будет принимать пользовательский ввод
Я пишу программу, чтобы определить, является ли год високосным. Это задание, поэтому я должен использовать четыре метода, которые я написал внутри программы. Программа компилируется и запускается, запрашивает ввод пользователя в соответствующих местах, но не принимает ввод в программу. Также говорится, что год является високосным и циклическим, независимо от того, что было введено. Я очень озадачен тем, где находится ошибка, так как эта программа, кажется, соответствует приведенным нами примерам.
import java.util.Scanner;
public class LeapYear {
public static void main(String[] args) {
boolean repeat;
String computeanother, yes="yes";
Scanner kb=new Scanner(System.in);
int year = -1;
boolean leap;
do
{
displayInstructions();
getYear(year);
leap = isLeap(year);
displayResults(year, leap);
System.out.println("Would you like to compute another year?");
computeanother = kb.nextLine();
if(computeanother.equals(yes))
repeat=true;
else
repeat=false;
} while(repeat=true);
}
public static void displayInstructions()
{
System.out.println("This program is designed to predict whether or not a year is a leap year.");
System.out.println("When prompted please enter a positive number for the year.");
System.out.println("Once the program has run completely, it will state the year and whether it is a leap year.");
}
public static void getYear(int year)
{
Scanner kb = new Scanner(System.in);
do {
System.out.println("Please enter the year.");
year=kb.nextInt();
} while (year < 0);
}
public static boolean isLeap(int year)
{
boolean leap;
if ((year%4==0 && year%100 != 0) || year%400==0){
leap = true;
return true;
} else {
leap = false;
return false;
}
}
public static void displayResults(int year, boolean leap)
{
if (leap = true) {
System.out.println("The year " +year);
System.out.println("is a leap year.");
} else {
System.out.println("The year " +year);
System.out.println("is not a leap year.");
}
}
}
Спасибо всем за помощь! Отредактированный код выглядит так:
import java.util.Scanner;
public class LeapYear{
public static void main(String[] args){
boolean repeat;
String computeanother, yes="yes";
Scanner kb=new Scanner(System.in);
int year = -1;
boolean leap;
do
{
displayInstructions();
getYear(year);
leap = isLeap(year);
displayResults(year, leap);
System.out.println("Would you like to compute another year?");
computeanother = kb.nextLine();
repeat = computeanother.equals(yes);
}while(repeat);
}
public static void displayInstructions()
{
System.out.println("This program is designed to predict whether or not a year is a leap year.");
System.out.println("When prompted please enter a positive number for the year.");
System.out.println("Once the program has run completely, it will state the year and whether it is a leap year.");
}
public static int getYear(int year)
{
Scanner kb = new Scanner(System.in);
do{
System.out.println("Please enter the year.");
year=kb.nextInt();
}while (year < 0);
return year;
}
public static boolean isLeap(int year)
{
boolean leap;
year = getYear(year);
if ((year%4==0 && year%100 != 0) || year%400==0){
leap = true;
return true;}
else{
leap = false;
return false;}
}
public static int displayResults(int year, boolean leap)
{
year = getYear(year);
if (leap == true){
System.out.println("The year " +year);
System.out.println("is a leap year.");}
else{
System.out.println("The year " +year);
System.out.println("is not a leap year.");}
return year;
}
}
3 ответа
Изменить это:
while(repeat=true);
в
while(repeat==true);
или же
while(repeat);
Вот while(repeat=true);
Вы присваиваете значение, а не сравниваете. while(repeat==true);
или же while(repeat);
это будет сравнивать значение. Всегда лучше тестировать вот так while(repeat);
вместо очевидного while(repeat==true);
, Я надеюсь, что это помогает.
И вы не получаете ценность для year
как -1, потому что вы возвращаетесь из этого метода getYear(year);
но игнорируя значение. Измените это на:
year = getYear(year);
Это должно работать.
Вы также можете сократить свой код:
do{
displayInstructions();
getYear(year);
leap = isLeap(year);
displayResults(year, leap);
System.out.println("Would you like to compute another year?");
computeanother = kb.nextLine();
repeat = computeanother.equals(yes) //this line makes code shorter
} while(repeat);
Действительно, всегда избегайте избыточности кода, как этот известный шаблон:
if(expression) return true; else return false;
Это становится: return expression;
while(repeat=true);
В цикле while должно быть:
while(repeat == true);
или же
while(repeat);
Помимо того, что все это отметили, можно заметить, что вы совершаете эту ошибку дважды:
if (leap = true) {
Должно быть:
if (leap == true) {
или же
if (leap) {