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

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

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

 
 Ответить  Открыть новую тему 
> шахматный слон
art88
сообщение 10.10.2005 15:12
Сообщение #1


Новичок
*

Группа: Пользователи
Сообщений: 40
Пол: Мужской
Реальное имя: Артём

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


Нужна помощь, срочно!
-----------------------------
Поле шахматной доски занумеровано цифрами от 1 до 8.
Нумерация начинается в левом нижнем углу.
Вводится начальная и конечная позиция слона, определить
может ли слон перейти из начальной в конечную позицию за один ход,
если нет узнать, как это можно сделать за два хода
(вывести промежуточную позицию).
-----------------------------
Для перемещения в один ход я сделал, а со вторым вариантом справиться н могу.
-----------------------------
см chess_el.pas


Прикрепленные файлы
Прикрепленный файл  CHESS_EL.PAS ( 491 байт ) Кол-во скачиваний: 193
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
Malice
сообщение 10.10.2005 16:20
Сообщение #2


Профи
****

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

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


Самый простой способ - перебор всех клеток доски и проверка твоего же условия для обоих клеток.
 Оффлайн  Профиль  PM 
 К началу страницы 
+ Ответить 
volvo
сообщение 11.10.2005 14:06
Сообщение #3


Гость






art88, дело в том, что возможны варианты, когда слон вообще не сможет перейти в указанную позицию (черный слон - в смысле, стоящий на черной клетке - никогда не попадет на белое поле и наоборот), так что сначала проверяй этот вариант:
If Odd(abs(m - k) + abs(n - l)) Then
WriteLn('Слон ВООБЩЕ не может перейти в указанную позицию')

:yes:
 К началу страницы 
+ Ответить 
art88
сообщение 11.10.2005 16:50
Сообщение #4


Новичок
*

Группа: Пользователи
Сообщений: 40
Пол: Мужской
Реальное имя: Артём

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


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

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

 



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