IPB
ЛогинПароль:

> Прочтите прежде чем задавать вопрос!

1. Заголовок темы должен быть информативным. В противном случае тема удаляется ...
2. Все тексты программ должны помещаться в теги [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ", если там не нашли ответа, воспользуйтесь ПОИСКОМ, возможно такую задачу уже решали!
4. Не предлагайте свои решения на других языках, кроме Паскаля (исключение - только с согласия модератора).
5. НЕ используйте форум для личного общения, все что не относится к обсуждению темы - на PM!
6. Одна тема - один вопрос (задача)
7. Проверяйте программы перед тем, как разместить их на форуме!!!
8. Спрашивайте и отвечайте четко и по существу!!!

 
 Ответить  Открыть новую тему 
> Задача про ферзей
Ola
сообщение 27.09.2003 6:20
Сообщение #1





Группа: Пользователи
Сообщений: 5

Репутация: -  0  +


Помогите, пожалуйста, решить задачу про ферзей: на шахматной доске размером NxN расставить N ферзей, чтобы они не били друг друга. ???
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
trminator
сообщение 27.09.2003 7:41
Сообщение #2


Четыре квадратика
****

Группа: Пользователи
Сообщений: 579
Пол: Мужской

Репутация: -  4  +


таак... универ пошел smile.gif

Если вкратце, то это почти полный перебор. Теперь подробнее

Сначала попробуй забыть, что это - ферзи. Пусть это будут ладьи. И расставляй ладей (ладьи? ладьев? брр...). Их хоть расставлять проще (чтобы была одна ладья в каждой строке и столбце).

Итак, у тебя есть как-то расставленные ладьи, друг друга не бьющие. Теперь остается проверить только диагонали smile.gif

Вариант: после расстановки ладей расставляй слонов. А ферзи - это такие ладьи, которые одновременно еще и слоны smile.gif


--------------------
Закон добровольного труда Зимерги:
Люди всегда согласны сделать работу, когда необходимость в этом уже отпала
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
zx1024
сообщение 1.10.2003 17:19
Сообщение #3


Пионер
**

Группа: Пользователи
Сообщений: 119
Пол: Мужской

Репутация: -  0  +


Перебор с возвратом по вертикалям.
i-ого ферзя ставим на i-ую вертикаль на "небьющееся" место. i := i + 1;
Если i=N+1, то выход(Ok).
Если место под ферзя не нашли, то возврат рекурсии.
(i := i - 1).
Если i=0, то выход (Косяк).
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
trminator
сообщение 2.10.2003 15:43
Сообщение #4


Четыре квадратика
****

Группа: Пользователи
Сообщений: 579
Пол: Мужской

Репутация: -  4  +


В принципе, достаточно хранить не матрицу, а вектор. Допустим, если в клетке [i, j] стоит ферзь, то A[i] = j
То есть надо заполнить вектор числами от 1 до n так, чтобы...

вроде так: | i - j | <> | A[i] - A[j] | - это условие того, что два ферзя, стоящие в клетках [ i, A[i] ] и [ j, A[j] ] не на одной диагонали.

ЗЫ Куда делся автор вопроса?


--------------------
Закон добровольного труда Зимерги:
Люди всегда согласны сделать работу, когда необходимость в этом уже отпала
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Ola
сообщение 4.10.2003 8:06
Сообщение #5





Группа: Пользователи
Сообщений: 5

Репутация: -  0  +


Прсто автор уже решила эту задачу с помощью книги Вирта. smile.gif Могу привести полностью программу.
Код
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
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
borlpasc.narod.ru
сообщение 4.10.2003 13:22
Сообщение #6


Пионер
**

Группа: Пользователи
Сообщений: 104
Пол: Мужской

Репутация: -  0  +


Ola
Все бы такие были!!! Молодец.!!!


--------------------
Заработок в Интернете www.webdengi.nm.ru
www.turbopascal.tk
FIDO 2:5028/63.29
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Sam0784
сообщение 6.05.2007 17:05
Сообщение #7


Новичок
*

Группа: Пользователи
Сообщений: 20
Пол: Мужской

Репутация: -  0  +


чёта непонятно что за массивы а б с как эта рекурсия работает.
вроде в цикле от1 од 8 и восемь раз вызывается а тветов больше чем 8*8 как так
мне во бет про ладьи надо мот кто подскажет.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 

 Ответить  Открыть новую тему 
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 



- Текстовая версия 19.07.2025 18:08
Хостинг предоставлен компанией "Веб Сервис Центр" при поддержке компании "ДокЛаб"