Problem Statement
Three friends enter a bus. There are two rows of seats with 10 seats in each row along the left and right side of the bus. For this problem, consider the seats to be points. Each seat in the same row is separated from the one in front of it and the one behind it by exactly 1 meter, and from the one directly opposite it (i.e., in the other row) by exactly 2 meters. Some of the seats are occupied by passengers. The friends want to know which seats they should occupy so as to minimize the sum of the Euclidean distances between each pair of friends. Recall that the Euclidean distance is simply the length of the line segment joining two points.
Create a class BusSeating that contains a method getArrangement. The method takes two
Definition
- Class:
- BusSeating
- Method:
- getArrangement
- Parameters:
- String, String
- Returns:
- double
- Method signature:
- double getArrangement(String leftRow, String rightRow)
- (be sure your method is public)
Notes
- Your return value must have an absolute or relative error less than 1e-9.
Constraints
- leftRow and rightRow will each contain exactly 10 characters.
- leftRow and rightRow will contain only the characters '-' and uppercase 'X'.
- There will be at least 3 empty seats among the 2 rows of seats.
Examples
"----------"
"----------"
Returns: 4.0
The minimum sum of distances in this situation is achieved when the three friends sit behind each other in the same row of seats, giving a minimum distance of 4.0.
"XXX-X-XX-X"
"-XXXX---XX"
Returns: 4.0
Once again, the friends can minimize the sum of distances by sitting behind each other in a row. This time, however, there is only one way to seat themselves in this manner.
"----------"
"-XXXX---XX"
Returns: 4.0
"-X-X-X-X-X"
"X-X-X-X-X-"
Returns: 6.47213595499958
"XXXXXXXXXX"
"-XX-XX-X--"
Returns: 6.0
"XXX-X-XX-X"
"XXX-X-XX-X"
Returns: 6.82842712474619
"X--X------"
"X-XXX---XX"
Returns: 4.0
"XXXXXXXXX-"
"--XXXXXXXX"
Returns: 18.465755708528206
"-X---X---X"
"X--XXX---X"
Returns: 4.0
"XX--------"
"XX-XX-XXXX"
Returns: 4.0
"X-XX-X--X-"
"X-XX--XX--"
Returns: 5.23606797749979
"XXXXX---XX"
"X-X-XXX-X-"
Returns: 4.0
"-X---X----"
"-XXXX-XX--"
Returns: 4.0
"-XXX--XX--"
"-XX-X-XX-X"
Returns: 5.23606797749979
"X-X-X-X-XX"
"-XXX-X-X--"
Returns: 6.0
"--XXX-X-XX"
"--XXX-X---"
Returns: 4.0
"XXX--XX-X-"
"XX---XX---"
Returns: 4.0
"X-XXX-X---"
"-XXX-X-X-X"
Returns: 4.0
"XX--XXX-XX"
"X-X-X--X--"
Returns: 5.23606797749979
"X-X-XXX-XX"
"X-----X---"
Returns: 4.0
"XX-XX-XXX-"
"X--X---X-X"
Returns: 4.0
"XX-XXXX-XX"
"X-XXXXXXX-"
Returns: 13.56062329783655
"---XX-XXXX"
"X--X--XX--"
Returns: 4.0
"XX-X-X-XX-"
"X--XXXX-X-"
Returns: 5.23606797749979
"X-XXXXX---"
"--X-XXXX-X"
Returns: 4.0
"XXX---XX--"
"XX---XX---"
Returns: 4.0
"---XXX----"
"XXX-XX-X--"
Returns: 4.0
"XXXXXXXX-X"
"X--XXX-XX-"
Returns: 8.06449510224598
"XX--XXX--X"
"-------X--"
Returns: 4.0
"XX-XXX-X-X"
"-X--X-X---"
Returns: 4.0
"X--X----X-"
"--X-X-XX-X"
Returns: 4.0
"X--X-XXXXX"
"X--X--X-XX"
Returns: 5.23606797749979
"-XXX-X-X--"
"XX-XX-X-X-"
Returns: 5.23606797749979
"-XX--X--XX"
"XXX--XX---"
Returns: 4.0
"-XX-X---X-"
"-XXXXX-XXX"
Returns: 4.0
"X---XXX-XX"
"--X----X-X"
Returns: 4.0
"XXX--XXXXX"
"X-XXX-XXXX"
Returns: 6.06449510224598
"-XXXXXX--X"
"XX--X-XX--"
Returns: 5.23606797749979
"---XX---XX"
"X---X--X--"
Returns: 4.0
"-X--XX-X-X"
"X-X-----X-"
Returns: 4.0
"X--XXXXX-X"
"XXXXX-X-XX"
Returns: 7.841619252963779
"XX--X-XX--"
"XX-X-XX--X"
Returns: 5.23606797749979
"X-X-X-X--X"
"-XX-X-XX--"
Returns: 5.23606797749979
"-XXXXX--XX"
"XXX-X---X-"
Returns: 4.0
"XXX-X-XXXX"
"XXXX-XXXXX"
Returns: 6.47213595499958
"-X-XXXXX--"
"XXX-X-X-XX"
Returns: 6.06449510224598
"X-X--XX--X"
"X--XXX-X--"
Returns: 5.23606797749979
"XXXXXXXXXX"
"XXX-X-X-X-"
Returns: 8.0
"XX-X--X-X-"
"X-X-X-XX-X"
Returns: 5.23606797749979
"-X-XXXX-XX"
"-X-X--XXX-"
Returns: 6.0
"X--X--X-XX"
"XX-X-X-X-X"
Returns: 5.23606797749979
"X---XX---X"
"-XXX--X---"
Returns: 4.0
"XXX--XX-XX"
"XX--XXXX-X"
Returns: 5.23606797749979
"X-X-XX--X-"
"--XX-XX-X-"
Returns: 5.23606797749979
"XXXXX-X--X"
"XXXXXX--XX"
Returns: 5.23606797749979
"----X-X--X"
"X---XXX-XX"
Returns: 4.0
"-XXXXXXXX-"
"-XXXXXXXX-"
Returns: 20.219544457292887
"--X-X-XX--"
"X--XX--X--"
Returns: 5.23606797749979
"-X--X-XXX-"
"X-X--XXXX-"
Returns: 5.23606797749979
"-X-XXXX-XX"
"XXXXXXXXX-"
Returns: 14.0
"XX-X--X--X"
"-X-X-X-XXX"
Returns: 5.23606797749979
"-X--XX--X-"
"-X--X-X--X"
Returns: 5.23606797749979
"-X--X-X-X-"
"XXXX-X-X-X"
Returns: 6.0
"--XXX-X--X"
"X-X-XX--X-"
Returns: 5.23606797749979
"-XXX-XXXXX"
"--XXX-X---"
Returns: 4.0
"-XXX-X--X-"
"-XX-XXX--X"
Returns: 5.23606797749979
"-X-XX--X--"
"X-XXXXXXXX"
Returns: 6.0
"X-X-XX-X--"
"XX-XXXXXXX"
Returns: 6.0
"XX-X-X-X--"
"XXX-XXXXXX"
Returns: 6.0
"XXX-XX-X--"
"XX-X-XXXXX"
Returns: 6.0
"X-X-X-X-X-"
"-X-X-X-X-X"
Returns: 6.47213595499958
"XXX-X-XX-X"
"XXX-X-XX-X"
Returns: 6.82842712474619
"XXXXXXXXXX"
"-XX-XX-X--"
Returns: 6.0
"----------"
"----------"
Returns: 4.0
"XXXXXXXXX-"
"--XXXXXXXX"
Returns: 18.465755708528206
"---XXXXXXX"
"XXXXXXXXXX"
Returns: 4.0
"------XXXX"
"----------"
Returns: 4.0
"-XXXXXXXX-"
"-XXXXXXXXX"
Returns: 20.219544457292887
"XXXXXXXXXX"
"---XXX---X"
Returns: 4.0
"XXXXXXXXXX"
"---XXXXXXX"
Returns: 4.0
"-XXXXXXXX-"
"XXXXX-XXXX"
Returns: 18.857300762134084
"XXXXX-XXXX"
"-XXXXXXXX-"
Returns: 18.857300762134084
"XXXXXXXXX-"
"--XXXXXX--"
Returns: 5.23606797749979
"XXXXXXXXX-"
"XXXXXXXX--"
Returns: 5.23606797749979