![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() |
Ola |
![]()
Сообщение
#1
|
![]() Группа: Пользователи Сообщений: 5 Репутация: ![]() ![]() ![]() |
Помогите, пожалуйста, решить задачу про ферзей: на шахматной доске размером NxN расставить N ферзей, чтобы они не били друг друга. ???
|
![]() ![]() |
zx1024 |
![]()
Сообщение
#2
|
![]() Пионер ![]() ![]() Группа: Пользователи Сообщений: 119 Пол: Мужской Репутация: ![]() ![]() ![]() |
Перебор с возвратом по вертикалям.
i-ого ферзя ставим на i-ую вертикаль на "небьющееся" место. i := i + 1; Если i=N+1, то выход(Ok). Если место под ферзя не нашли, то возврат рекурсии. (i := i - 1). Если i=0, то выход (Косяк). |
![]() ![]() |
![]() |
Текстовая версия | 20.07.2025 10:56 |