Back to questions
Intern
3
""" Места в кинотеатре расположены в один ряд. Только что пришедший зритель выбирает место, чтобы сидеть максимально далеко от остальных зрителей в ряду. То есть расстояние от того места, куда сядет зритель до ближайшего к нему зрителя должно быть максимально. Гарантируется, что в ряду всегда есть свободные места и уже сидит хотя бы один зритель. Напишите функцию, которая по заданному ряду мест (массиву из нулей и единиц) вернёт расстояние (число промежутков между креслами) от выбранного места до ближайшего зрителя. [1, 0, 0, 0, 1] -> 2 [1, 0, 1, 0, 0, 1, 0, 0, 1] -> 2 [1, 0, 1, 0] -> 1 [0, 0, 0, 1] -> 3 [1, 0, 0, 0] -> 3 place = ((right - left) / 2) """ func maxPlaces(arr []int) int { }
Companies where asked
Яндекс
Answer from AI
sobes.tech AI
Чтобы найти максимальное расстояние до ближайшего зрителя, нужно рассмотреть три ситуации:
- Свободные места в начале ряда до первого занятого места.
- Свободные места в конце ряда после последнего занятого места.
- Свободные места между двумя занятыми местами — в этом случае выбираем середину промежутка.
Алгоритм:
- Пройти по ряду, найти индексы занятых мест.
- Рассчитать расстояния в начале и в конце ряда.
- Для каждого промежутка между занятыми местами вычислить половину длины промежутка (округляя вниз).
- Максимальное из этих значений и будет ответом.
Пример реализации на Go:
func maxPlaces(arr []int) int {
n := len(arr)
left := -1
maxDist := 0
// Найдем первое занятое место
for i, seat := range arr {
if seat == 1 {
left = i
maxDist = left // расстояние от начала ряда
break
}
}
// Пройдем по ряду, чтобы найти максимальное расстояние между занятыми местами
for i := left + 1; i < n; i++ {
if arr[i] == 1 {
dist := (i - left) / 2
if dist > maxDist {
maxDist = dist
}
left = i
}
}
// Проверим расстояние от последнего занятого места до конца ряда
if n-1-left > maxDist {
maxDist = n - 1 - left
}
return maxDist
}
Этот код возвращает максимальное расстояние до ближайшего зрителя, куда сядет новый зритель.