Назад к вопросам
Яндекс Маркет
Middle
3
/** * Дан массив точек с целочисленными координатами (x, y). * Определить, существует ли вертикальная прямая, * делящая точки на 2 симметричных относительно этой прямой набора. * Note: Для удобства точку можно представлять не как массив [x, y], а как объект {x, y} */ isVertSym([[0, 0], [0, 0], [1, 1], [2, 2], [3, 1], [4, 0], [4, 0]]) // true isVertSym([[0, 0], [0, 0], [1, 1], [2, 2], [3, 1], [4, 0]]) // false isVertSym([]) // true isVertSym([[0, 0]]) // true isVertSym([[0, 0], [10, 0]]) // true isVertSym([[0, 0], [11, 1]]) // false isVertSym([[0, 0], [1, 0], [3, 0]]) // false function isVertSym(list) { // code here }
Компании, где спрашивали
Ответ от нейросети
sobes.tech AI
Для проверки, существует ли вертикальная ось симметрии, можно:
- Найти минимальное и максимальное значение x среди точек.
- Вычислить потенциальную ось симметрии как
mid = (minX + maxX) / 2. - Для каждой точки проверить, существует ли зеркальная точка относительно этой оси.
Для удобства можно использовать структуру данных, например, Map или Set, чтобы быстро проверять наличие зеркальных точек.
Пример реализации на JavaScript:
function isVertSym(points) {
if (points.length <= 1) return true;
let minX = Infinity, maxX = -Infinity;
const pointSet = new Set();
for (const [x, y] of points) {
minX = Math.min(minX, x);
maxX = Math.max(maxX, x);
pointSet.add(`${x},${y}`);
}
const mid = (minX + maxX) / 2;
for (const [x, y] of points) {
const mirroredX = 2 * mid - x;
if (!pointSet.has(`${mirroredX},${y}`)) {
return false;
}
}
return true;
}
Этот код проверяет, что для каждой точки существует зеркальная точка относительно вертикальной линии x = mid. Если для всех точек это условие выполняется, функция возвращает true, иначе — false.