Count the number of open lockers in school

Carvia Tech | May 19, 2019 | 1 min read | 276 views | Python Coding Problems

School Daze

A group of schools has a specific number of lockers and a specific number of students. All lockers are closed on the first day of school. As students get to school they begin to play with the lockers. The first student opens every locker. The second student begins with the 2nd locker and closes every other locker. The third student starts with the third locker and changes every 3rd locker. That is, the third student opens the locker if it is closed and closes it if it is open. The 4th student starts with locker 4 and changes every 4th locker and so on. After all the students are done, display how many lockers are open.

Test data
Input Output

100, 100

100 Lockers: 100 Students; 10 Open lockers

10, 5

10 Lockers; 5 Students; 6 Open lockers

1000, 50

1000 Lockers; 50 Students; 499 Open lockers

Get Open Lockers
def get_open_lockers(num_lockers, num_students):
    list_lockers = ["open"]*num_lockers # 1st step
    for k in range(2,num_students+1): # others
        for i,j in enumerate(list_lockers):
            if (i+1)>=(k-1):
                if (i+1)%k==0:
                    if list_lockers[i] == "open":
                        list_lockers[i] = "close"
                        list_lockers[i] = "open"
    return list_lockers.count("open")

print(get_open_lockers(100, 100))

Python Coding Problems:
  1. Python coding challenges for interviews
  2. Write a program to check if the given word is Isogram & Pair isogram in python
  3. Pass the ball game: NxN matrix in python
  4. Find if credit card number is valid or not
  5. Find extra long factorials in python
  6. Spaced Out?
  7. Sequence of Differences in Python
See all articles in Python Coding Problems
Top articles in this category:
  1. Python coding challenges for interviews
  2. Flask Interview Questions
  3. Google Data Scientist interview questions with answers
  4. Top 100 interview questions on Data Science & Machine Learning
  5. Write a program to find if a number is Lychrel Number in Python
  6. Sequence of Differences in Python
  7. Pass the ball game: NxN matrix in python

Find more on this topic:
Machine Learning image
Machine Learning

Data science, machine learning, python, R, big data, spark, the Jupyter notebook, and much more

Last updated 1 week ago

Recommended books for interview preparation:

This website uses cookies to ensure you get the best experience on our website. more info