-
Notifications
You must be signed in to change notification settings - Fork 17
/
ProgrammerInCinemaDuringCovid.java
83 lines (75 loc) · 2.75 KB
/
ProgrammerInCinemaDuringCovid.java
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
package by.andd3dfx.common;
import lombok.AllArgsConstructor;
import lombok.ToString;
import java.util.ArrayList;
import java.util.List;
/**
* <pre>
* Программист решил пойти в кино. Но он хочет сесть как можно дальше от других людей, чтобы не заразиться covid.
* Поэтому он хочет написать функцию, определяющую максимальное расстояние,
* на котором можно сесть от других зрителей в одном ряду.
*
* Дан массив из 0 и 1 описывающий посадку зрителей в ряду.
* 0 - место свободно, 1 - место занято другим зрителем.
* Вывести максимальное расстояние, на котором можно сесть от других зрителей.
* Гарантируется, что есть 0 и 1.
*
* Примеры:
* [1,0,0,0,1] -> 2
* [1,0,0,0,0,1] -> 2
* [1,0,0,0,0,0,1] -> 3
* [1,0,0,0,0,0,1,0,0,1] -> 3
* [1,0,0,0] -> 3
* [0,0,1,0] -> 2
* </pre>
*
* @see <a href="https://youtu.be/ClBUqbfSJ18">Video solution</a>
*/
public class ProgrammerInCinemaDuringCovid {
public static int find(int[] places) {
var leftFound = false;
var left = -1;
var right = -1;
List<Interval> intervals = new ArrayList<>();
for (int current = 0; current < places.length; current++) {
if (places[current] == 0) {
right = current;
if (!leftFound) {
leftFound = true;
left = current;
}
} else {
if (leftFound) {
intervals.add(new Interval(left, right));
leftFound = false;
}
}
}
if (leftFound) {
intervals.add(new Interval(left, right));
}
int maxDistance = 0;
for (var interval : intervals) {
int distance = determineDistance(interval, places.length);
if (distance > maxDistance) {
maxDistance = distance;
}
}
return maxDistance;
}
private static int determineDistance(Interval interval, int size) {
if (interval.left == 0) {
return interval.right + 1;
}
if (interval.right == size - 1) {
return size - interval.left;
}
return (interval.right - interval.left + 2) / 2;
}
@ToString
@AllArgsConstructor
public static class Interval {
private int left;
private int right;
}
}