![]() |
1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!
![]() ![]() |
![]() |
Ola |
![]()
Сообщение
#1
|
![]() Группа: Пользователи Сообщений: 5 Репутация: ![]() ![]() ![]() |
Помогите, пожалуйста, решить задачу про ферзей: на шахматной доске размером NxN расставить N ферзей, чтобы они не били друг друга. ???
|
trminator |
![]()
Сообщение
#2
|
Четыре квадратика ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 579 Пол: Мужской Репутация: ![]() ![]() ![]() |
таак... универ пошел
![]() Если вкратце, то это почти полный перебор. Теперь подробнее Сначала попробуй забыть, что это - ферзи. Пусть это будут ладьи. И расставляй ладей (ладьи? ладьев? брр...). Их хоть расставлять проще (чтобы была одна ладья в каждой строке и столбце). Итак, у тебя есть как-то расставленные ладьи, друг друга не бьющие. Теперь остается проверить только диагонали ![]() Вариант: после расстановки ладей расставляй слонов. А ферзи - это такие ладьи, которые одновременно еще и слоны ![]() -------------------- Закон добровольного труда Зимерги:
Люди всегда согласны сделать работу, когда необходимость в этом уже отпала |
zx1024 |
![]()
Сообщение
#3
|
![]() Пионер ![]() ![]() Группа: Пользователи Сообщений: 119 Пол: Мужской Репутация: ![]() ![]() ![]() |
Перебор с возвратом по вертикалям.
i-ого ферзя ставим на i-ую вертикаль на "небьющееся" место. i := i + 1; Если i=N+1, то выход(Ok). Если место под ферзя не нашли, то возврат рекурсии. (i := i - 1). Если i=0, то выход (Косяк). |
trminator |
![]()
Сообщение
#4
|
Четыре квадратика ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 579 Пол: Мужской Репутация: ![]() ![]() ![]() |
В принципе, достаточно хранить не матрицу, а вектор. Допустим, если в клетке [i, j] стоит ферзь, то A[i] = j
То есть надо заполнить вектор числами от 1 до n так, чтобы... вроде так: | i - j | <> | A[i] - A[j] | - это условие того, что два ферзя, стоящие в клетках [ i, A[i] ] и [ j, A[j] ] не на одной диагонали. ЗЫ Куда делся автор вопроса? -------------------- Закон добровольного труда Зимерги:
Люди всегда согласны сделать работу, когда необходимость в этом уже отпала |
Ola |
![]()
Сообщение
#5
|
![]() Группа: Пользователи Сообщений: 5 Репутация: ![]() ![]() ![]() |
Прсто автор уже решила эту задачу с помощью книги Вирта.
![]() Код uses crt; var i:integer; a:array[1..8] of boolean; b:array[2..16] of boolean; c:array[-7..7] of boolean; x:array[1..8] of integer; procedure Print; var k:integer; begin for k:=1 to 8 do write(x[k]:3); writeln; end; procedure Try(i:integer); var j:integer; begin for j:=1 to 8 do if (a[j]=true) and (b[i+j]=true) and (c[i-j]=true) then begin x[i]:=j; a[j]:=false;b[i+j]:=false;c[i-j]:=false; if i<8 then try(i+1) else print; procedure Try(i:integer); var j:integer; begin for j:=1 to 8 do if (a[j]=true) and (b[i+j]=true) and (c[i-j]=true) then begin x[i]:=j; a[j]:=false;b[i+j]:=false;c[i-j]:=false; if i<8 then try(i+1) else print; a[j]:=true;b[i+j]:=true;c[i-j]:=true; end; end; begin clrscr; for i:=1 to 8 do a[i]:=true; for i:=2 to 16 do b[i]:=true; for i:=-7 to 7 do c[i]:=true; try(1); readln; end. Сообщение отредактировано: volvo - 17.12.2004 14:23 |
borlpasc.narod.ru |
![]()
Сообщение
#6
|
Пионер ![]() ![]() Группа: Пользователи Сообщений: 104 Пол: Мужской Репутация: ![]() ![]() ![]() |
Ola
Все бы такие были!!! Молодец.!!! -------------------- Заработок в Интернете www.webdengi.nm.ru
www.turbopascal.tk FIDO 2:5028/63.29 |
Sam0784 |
![]()
Сообщение
#7
|
Новичок ![]() Группа: Пользователи Сообщений: 20 Пол: Мужской Репутация: ![]() ![]() ![]() |
чёта непонятно что за массивы а б с как эта рекурсия работает.
вроде в цикле от1 од 8 и восемь раз вызывается а тветов больше чем 8*8 как так мне во бет про ладьи надо мот кто подскажет. |
![]() ![]() |
![]() |
Текстовая версия | 19.07.2025 18:08 |