There are 100 doors, all closed. In a nearby cage are 100 monkeys. The first monkey is let out, and runs along the doors opening every one. The second monkey is then let out, and runs along the doors closing the 2nd, 4th, 6th,… all the even-numbered doors. The third monkey is let out. He attends only to the 3rd, 6th, 9th,… doors (every third door, in other words), closing any that is open and opening any that is closed, and so on. After all 100 monkeys have done their work in this way, what state are the doors in after the last pass, which doors are left open and which are closed ?
See Solution : 100 doorsFacebook Comments
Gaurav khurana says
Here is the javacode to test this
package javaPractise;
public class DoorOpen {
public static void main(String[] args) {
// TODO Auto-generated method stub
int length=101;
int arr[]=new int[length]; // by default all doors are closed . Lets assume
System.out.println(“0 is closed”);
System.out.println(“1 is open”);
for (int i=1;i <length; i++)
{
// System.out.println();
for(int j=i; j<length && j<=100; j=j+i)
{
// Lets revert the condition on each pass , if o(closed) then 1(open) and vice versa
if(arr[j]==0)
{
arr[j]=1; // door is open now
}
else if(arr[j]==1)
{
arr[j]=0; // Door is closed
}
}
}
System.out.println(" The below doors are open");
for (int i=1;i <length; i++)
{
if(arr[i]==1)
{
System.out.println(i);
}
}
}
}
Mary says
1,7,11,13,17,19,23,29,31,37,41,43,47,53,59,,61,67,71,73,79,83,89,97 are open.remaining are closed
vinay says
1,4,9,16,25,36,49,64,81,100 are open.remaining are closed. only these numbers(perfect squares) having odd no.of factors.