A high school has 1000 students and 1000 lockers, one locker for each student. On the first day of school, the principal plays the following game: She asks the first student to open all the lockers. She then asks the second student to close all the even-numbered lockers. The third student is asked to check every third locker. If it is open, the student closes it; if it is closed, the student opens it. The fourth student is asked to check every fourth locker. If it is open, the student closes it; if it is closed, the student opens it. The remaining students continue this game. In general, the nth student checks every nth locker. If it is open, the student closes it; if it is closed, the student opens it. After all the students have taken turns, some of the lockers are open and some are closed. The program below, when ran, will prompt the user to enter the number of lockers in the school. After the game is over, the program will output the number of lockers and the lockers numbers of the lockers that are open. However, the statements are in the wrong order, and there are some bugs in this program. Rearrange the statements and also find and remove the bugs so that the program can run properly. RENAME THE CLASS TO "LASTNAME_CLASSCODE_LOCKER".

Database System Concepts
7th Edition
ISBN:9780078022159
Author:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Chapter1: Introduction
Section: Chapter Questions
Problem 1PE
icon
Related questions
Question

Use java language

A high school has 1000 students and 1000 lockers, one locker for each student. On the first day of school, the
principal plays the following game: She asks the first student to open all the lockers. She then asks the second
student to close all the even-numbered lockers. The third student is asked to check every third locker. If it is
open, the student closes it; if it is closed, the student opens it. The fourth student is asked to check every fourth
locker. If it is open, the student closes it; if it is closed, the student opens it. The remaining students continue
this game. In general, the nth student checks every nth locker. If it is open, the student closes it; if it is closed,
the student opens it. After all the students have taken turns, some of the lockers are open and some are closed.
The program below, when ran, will prompt the user to enter the number of lockers in the school. After the
game is over, the program will output the number of lockers and the lockers numbers of the lockers that are
open. However, the statements are in the wrong order, and there are some bugs in this program. Rearrange the
statements and also find and remove the bugs so that the program can run properly. RENAME THE CLASS TO
"LASTNAME_CLASSCODE_LOCKER".
/**
* The program below, while has the correct output, doesn't follow the game's logic at all.
* Instead, it follows a certain pattern that's present in the game.
Consider the 100th locker. Following the games rules, this locker should be visited by the 1st, 2nd,
* 3rd, 4th, 5th, 10th, 20th, 25th, 50th, and 100th student. Coincidentally, these are also the positive
* divisors of 100. Similarly, the 30th locker is visited by the students whose numbers are 1, 2, 3, 5,
* 6, 10, 15, and 30. Note that if the numbers of positive divisors of a locker number is odd, then at
* the end of the game, the locker is open. if the numbers of positive divisors of a locker number is
even, then at the end of the game, the locker is closed.
*/
import java.util.Random;
public class Locker{
public static void main(String[] args){
Scanner keyboard = new Scanner(System.in);
int studentVisitCount = 0;
System.out.print ("Enter the number of lockers: ");
int numberOfLockers = console.nextInt();
for(int x-0; x<=number0fLockers; x++){
if(x%y==0){
studentVisitCount--;
}
for(int y=0; y<=x; y++){
if(studentVisitCount%3!=0){
System.out.print(y+" ");
}
}
}
System.out. println("The number of lockers and students are: "+number0fLockers);
System.out.print("The locker numbers left open at the end of the game are: ");
}
}
Transcribed Image Text:A high school has 1000 students and 1000 lockers, one locker for each student. On the first day of school, the principal plays the following game: She asks the first student to open all the lockers. She then asks the second student to close all the even-numbered lockers. The third student is asked to check every third locker. If it is open, the student closes it; if it is closed, the student opens it. The fourth student is asked to check every fourth locker. If it is open, the student closes it; if it is closed, the student opens it. The remaining students continue this game. In general, the nth student checks every nth locker. If it is open, the student closes it; if it is closed, the student opens it. After all the students have taken turns, some of the lockers are open and some are closed. The program below, when ran, will prompt the user to enter the number of lockers in the school. After the game is over, the program will output the number of lockers and the lockers numbers of the lockers that are open. However, the statements are in the wrong order, and there are some bugs in this program. Rearrange the statements and also find and remove the bugs so that the program can run properly. RENAME THE CLASS TO "LASTNAME_CLASSCODE_LOCKER". /** * The program below, while has the correct output, doesn't follow the game's logic at all. * Instead, it follows a certain pattern that's present in the game. Consider the 100th locker. Following the games rules, this locker should be visited by the 1st, 2nd, * 3rd, 4th, 5th, 10th, 20th, 25th, 50th, and 100th student. Coincidentally, these are also the positive * divisors of 100. Similarly, the 30th locker is visited by the students whose numbers are 1, 2, 3, 5, * 6, 10, 15, and 30. Note that if the numbers of positive divisors of a locker number is odd, then at * the end of the game, the locker is open. if the numbers of positive divisors of a locker number is even, then at the end of the game, the locker is closed. */ import java.util.Random; public class Locker{ public static void main(String[] args){ Scanner keyboard = new Scanner(System.in); int studentVisitCount = 0; System.out.print ("Enter the number of lockers: "); int numberOfLockers = console.nextInt(); for(int x-0; x<=number0fLockers; x++){ if(x%y==0){ studentVisitCount--; } for(int y=0; y<=x; y++){ if(studentVisitCount%3!=0){ System.out.print(y+" "); } } } System.out. println("The number of lockers and students are: "+number0fLockers); System.out.print("The locker numbers left open at the end of the game are: "); } }
Expert Solution
steps

Step by step

Solved in 3 steps with 2 images

Blurred answer
Knowledge Booster
Topological Sort
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Recommended textbooks for you
Database System Concepts
Database System Concepts
Computer Science
ISBN:
9780078022159
Author:
Abraham Silberschatz Professor, Henry F. Korth, S. Sudarshan
Publisher:
McGraw-Hill Education
Starting Out with Python (4th Edition)
Starting Out with Python (4th Edition)
Computer Science
ISBN:
9780134444321
Author:
Tony Gaddis
Publisher:
PEARSON
Digital Fundamentals (11th Edition)
Digital Fundamentals (11th Edition)
Computer Science
ISBN:
9780132737968
Author:
Thomas L. Floyd
Publisher:
PEARSON
C How to Program (8th Edition)
C How to Program (8th Edition)
Computer Science
ISBN:
9780133976892
Author:
Paul J. Deitel, Harvey Deitel
Publisher:
PEARSON
Database Systems: Design, Implementation, & Manag…
Database Systems: Design, Implementation, & Manag…
Computer Science
ISBN:
9781337627900
Author:
Carlos Coronel, Steven Morris
Publisher:
Cengage Learning
Programmable Logic Controllers
Programmable Logic Controllers
Computer Science
ISBN:
9780073373843
Author:
Frank D. Petruzella
Publisher:
McGraw-Hill Education