The Optimal Urinal Problem
Difficulty : Medium
Community success rate: 42%
Approved by JBM an anonymous CodinGamer java_coffee_cup
A higher resolution is required to access the IDE
- 118
Statement
Goal
You and your schoolmates from an all-boys school are going for a very exciting trip by bus. After some time, your bus stops so that the students can relieve themselves in a nearby public toilet.It happens that there are n urinals in a row in the public toilet.
Every guy knows that feeling: you enter the toilet, then you find the free urinal furthest away from all other occupied urinals.
Your schoolmates take it even further: they do not want to use a urinal if any of the urinals next to it is occupied.
You are the first guy among your schoolmates to enter the public toilet, initially all empty. Being the first, you have the privilege of choosing any urinal you want. You know that everyone is very excited and wants to continue the trip as soon as possible, and so you want to accommodate as many guys as possible at one time in the toilet.
Now, the question is: which urinal should you choose to maximize the number of guys that will use the toilet at one time, assuming all your schoolmates line up behind you and they will enter the toilet one by one, following these rules?
Rules
1. Other than you, each guy will pick the free urinal furthest away from any occupied urinals. If there are multiple such urinals, he will just pick any.
2. No guy will use a urinal if any of the urinals next to it is occupied.
Note that the urinals are 1-indexed, so the first urinal has index 1, the second one has index 2, and so on.
If there are multiple urinal indices that you can choose to achieve the objective, output the smallest one.
Example
If there are
Time 1:
1000000
Time 2:
1000001
Time 3:
1001001
Note that no more guys will use the urinals at this point, since it will violate rule 2.
However, if you choose urinal with index 3, you can fit 4 guys:
Time 1:
0010000
Time 2:
0010001
Time 3:
1010001
Time 4:
1010101
This is the maximum, so you should output
Input
An integer n representing the number of urinals in the public toilet.
Output
Two integers k and i separated by a space.
k represents the maximum number of guys that can use the toilet at one time.
i represents the smallest index of the urinal that you should choose.
k represents the maximum number of guys that can use the toilet at one time.
i represents the smallest index of the urinal that you should choose.
Constraints
2 <= n <= 1500000
Example
Input
3
Output
2 1
A higher resolution is required to access the IDE