Advertisement
Guest User

100 Seats

a guest
Mar 19th, 2018
55
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C# 1.78 KB | None | 0 0
  1. using System;
  2. using System.Collections.Generic;
  3. using System.Linq;
  4. using System.Text;
  5. using System.Threading.Tasks;
  6.  
  7. namespace SeatProblem
  8. {
  9.     class Program
  10.     {
  11.         //entry point
  12.         public static void Main()
  13.         {    
  14.             Random rng = new Random(); //Create a RNG
  15.             const int n = 10000000; //number of trials
  16.             int lastSeatAvailableCounter = 0; //counter that we will increase each time the last seat is available
  17.  
  18.             //loop N times
  19.             for (int trials = 0; trials < n; trials++)
  20.             {      
  21.                 int[] seats = new int[100]; //array of 100 seats
  22.  
  23.                 //fill the seats array with 0
  24.                 for (int i = 0; i < 100; i++)
  25.                     seats[i] = 0;
  26.  
  27.                 //pick a random seat for first person
  28.                 int firstSeat = rng.Next(0,100);
  29.                 seats[firstSeat] = 1;
  30.  
  31.                 //loop to seat people 2-100
  32.                 int currentPerson = 2;
  33.                 while (currentPerson <= 99)
  34.                 {    
  35.                     int seatNumber = currentPerson - 1;
  36.  
  37.                     while (seats[seatNumber] != 0)
  38.                         seatNumber = rng.Next(0,100); //pick a random number from 0-100 (not inclusive of 100)
  39.  
  40.                     seats[seatNumber] = currentPerson;
  41.                     currentPerson++;
  42.                 }
  43.  
  44.                 //if last seat is available, increment counter by 1
  45.                 if (seats[99] == 0)
  46.                     lastSeatAvailableCounter++;
  47.             }
  48.  
  49.             double result = (double)lastSeatAvailableCounter / (double)n;
  50.             Console.WriteLine(lastSeatAvailableCounter);
  51.             Console.WriteLine(result);
  52.             Console.ReadKey();
  53.  
  54.         }
  55.     }
  56. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement