Задача про ферзей Испытание курса: JS: Последовательности

Задача о восьми ферзях — широко известная задача по расстановке фигур на шахматной доске. Исходная формулировка: "Расставить на стандартной 64-клеточной шахматной доске 8 ферзей так, чтобы ни один из них не находился под боем другого". Подразумевается, что ферзь бьёт все клетки, расположенные по вертикалям, горизонталям и обеим диагоналям.

// из материалов Википедии

Задачу можно обобщить следующим образом: "На шахматной доске со стороной N, расставить N ферзей так, чтобы ни один из них не находился под боем другого".

isSafeQueens.js

Реализуйте и экспортируйте по умолчанию функцию, которая принимает комбинацию ферзей в виде списка и проверяет, является ли данная расстановка решением задачи.

Комбинации формируются следующим образом:

(2, 4, 1, 3)

где каждое число — это позиция ферзя по вертикали, а порядок числа в списке — позиция ферзя по горизонтали.

Для примера выше, доска будет выглядеть так:

     1   2   3   4
    ___ ___ ___ ___
1  |___|___|_*_|___|
2  |_*_|___|___|___|
3  |___|___|___|_*_|
4  |___|_*_|___|___|

Примеры:

import isSafeQueens from '../isSafeQueens.js';

const queens = l(2, 4, 1, 3);

isSafeQueens(queens); // true
Успешных завершений: 65%

Для полного доступа к испытанию нужна профессиональная подписка

Профессиональная подписка откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, даст возможность обращаться за помощью к менторам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.

Получить доступ
115
курсов
892
упражнения
2241
час теории
3196
тестов

Последние код-ревью

Автор Дата обновления Версий
alex_rdn 06 сент., 10:16 1
user-a6879c4152f9ff6b 15 июля, 17:28 1
masterflo 11 июля, 09:21 2
alexk 19 июня, 18:02 1
orionbetel 11 июня, 06:16 1