Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.64/88: Рейтинг темы: голосов - 88, средняя оценка - 4.64
0 / 0 / 0
Регистрация: 11.06.2018
Сообщений: 8

Шахматы

26.11.2020, 21:36. Показов 18473. Ответов 6

Студворк — интернет-сервис помощи студентам
Здравствуйте. Решал вот эту задачу:


Совсем недавно Вася занялся программированием и решил реализовать собственную программу для игры в шахматы. Но у него возникла проблема определения правильности хода конем, который делает пользователь. Т.е. если пользователь вводит значение «C7-D5», то программа должна определить это как правильный ход, если же введено «E2-E4», то ход неверный. Так же нужно проверить корректность записи ввода: если например, введено «D9-N5», то программа должна определить данную запись как ошибочную. Помогите ему осуществить эту проверку!

Входные данные
В единственной строке входного файла INPUT.TXT записан текст хода (непустая строка), который указал пользователь. Пользователь не может ввести строку, длиннее 5 символов.

Выходные данные
В выходной файл OUTPUT.TXT нужно вывести «YES», если указанный ход конем верный, если же запись корректна (в смысле правильности записи координат), но ход невозможен, то нужно вывести «NO». Если же координаты не определены или заданы некорректно, то вывести сообщение «ERROR».


Рассчитывал просто пройти и решать дальше, но постоянно не проходит седьмой тест.
Подскажите, что неверно. Вот код:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
import re
a = input()
b = re.search(r"..-..", a)
c = {
    "A": 1,
    "B": 2,
    "C": 3,
    "D": 4,
    "E": 5,
    "F": 6,
    "G": 7,
    "H": 8
}
 
try:
    if b[0]:
        x1 = int(c[b[0][0]])
        y1 = int(b[0][1])
        x2 = int(c[b[0][3]])
        y2 = int(b[0][4])
        dx = abs(x1 - x2)
        dy = abs(y1 - y2)
 
        if dx == 1 and dy == 2 or dx == 2 and dy == 1:
            print('YES')
        else:
            print('NO')
 
except KeyError:
    print("ERROR")
 
except TypeError:
    print("ERROR")
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
26.11.2020, 21:36
Ответы с готовыми решениями:

Шахматы
Вы уже сделали большую часть работы по реализации отдельных механик игры в шахматы. Остался последний шаг. Реализуйте полноценную игру...

Шахматы на доске
есть задача: Вам дана расстановка n фигур на доске, Программа получает на вход n пар чисел, каждое число от 1 до 8 — координаты n...

Почти шахматы
Переработайте приведённую в уроке программу «шахматы» таким образом, чтобы фигуры (за исключением коня) не могли ходить друг сквозь друга. ...

6
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,694
Записей в блоге: 29
27.11.2020, 08:19
Лучший ответ Сообщение было отмечено vsled как решение

Решение

Цитата Сообщение от vsled Посмотреть сообщение
что неверно.
неверно так называть перменные

Сразу дам три важных совета, которые не раз тебе помогут:
1) внимательно читай и несколько раз перечитывай задание, таск, ТЗ. Дьявол прячется в деталях и всегда есть нюанс который ты не учел (в данном случае ты игноришь цифры, например можно ввести 9 и твой код не покажет еррор)
2) всегда тестируй свой код, желательно полноценными тестами, но можно и ассертами (пример ниже). Причем я советую ассерты написать ДО кода
3) лучше код привыкать сразу писать функциями, а не потоком текста, так и тестировать удобнее и можно переиспользовать. А для решения твоей задачи просто попросить инпут и передать его в функцию

пример(твое решение тоже хорошее, просто надо допилить):
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
def check_move(move: str) -> str:
    allowed = 'ABCDEFGH'
    current, new = move.split('-')
    current_y = int(current[1])
    new_y = int(new[1])
    if current_y not in range(1, 9) or new_y not in range(1, 9) or current[0] not in allowed or new[0] not in allowed:
        return 'ERROR'
    variants = (lambda x, y, x1, y1: abs(x - x1) == 1 and abs(y - y1) == 2,
                lambda x, y, x1, y1: abs(x - x1) == 2 and abs(y - y1) == 1)
    for variant in variants:
        if variant(allowed.index(current[0]) + 1, current_y, allowed.index(new[0]) + 1, new_y):
            return 'YES'
    return 'NO'
 
 
if __name__ == '__main__':
    assert check_move('D9-C0') == 'ERROR'
    assert check_move('J7-C1') == 'ERROR'
    assert check_move('D8-C0') == 'ERROR'
    assert check_move('E2-E4') == 'NO'
    assert check_move('C3-C1') == 'NO'
    assert check_move('C3-E1') == 'NO'
    assert check_move('C3-B1') == 'YES'
    assert check_move('C3-D1') == 'YES'
    assert check_move('C3-A2') == 'YES'
    assert check_move('C3-E2') == 'YES'
    assert check_move('C3-A4') == 'YES'
    assert check_move('C3-E4') == 'YES'
    assert check_move('C3-B5') == 'YES'
    assert check_move('C3-D5') == 'YES'
    assert check_move('C7-D5') == 'YES'
если запустишь то ассерты не упадут, работает. Если в функцию вставишь свой код то сразу увидишь где проблема. Как уже говорил у тебя не ругается на D9-C0
2
710 / 356 / 104
Регистрация: 09.02.2018
Сообщений: 805
27.11.2020, 10:52
vsled, если что, решение Welemir1 тоже надо допиливать.

Но направление он тебе дал.
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
27.11.2020, 11:49
Python
1
2
3
4
5
6
7
8
9
10
import re
s = input()
if re.match(r'^[A-H][1-8]-[A-H][1-8]$', s):
    x1, y1, _, x2, y2 = map(ord, s)
    if (x1-x2)**2+(y1-y2)**2 == 5:
        print('YES')
    else:
        print('NO')
else:
    print('ERROR')
Лошадью ходи
3
Автоматизируй это!
Эксперт Python
 Аватар для Welemir1
7392 / 4819 / 1246
Регистрация: 30.03.2015
Сообщений: 13,694
Записей в блоге: 29
27.11.2020, 12:21

Не по теме:

eaa, чего у тебя за нарушения?



Добавлено через 29 секунд
Цитата Сообщение от eaa Посмотреть сообщение
re.match(r'^[A-H][1-8]-[A-H][1-8]$', s):
сильно заколдовано
0
Status 418
Эксперт Python
4584 / 2350 / 601
Регистрация: 26.11.2017
Сообщений: 5,262
Записей в блоге: 3
27.11.2020, 12:33

Не по теме:

Цитата Сообщение от Welemir1 Посмотреть сообщение
чего у тебя за нарушения?
курил на перемене в туалете :D
да из-за какого то олимпийского халявщика выписали, забыл тег оффтоп



Цитата Сообщение от Welemir1 Посмотреть сообщение
сильно заколдовано
увидел что ТС применяет модуль re, вот решил через регулярки.
0
0 / 0 / 0
Регистрация: 11.06.2018
Сообщений: 8
28.11.2020, 13:28  [ТС]
Про тесты знаю, обычно использую юниттесты. Про нейминг тоже знаю - задача простая, область использования - локальная, подразумевалось, что никто код видеть не будет) Насчет функций - не очень люблю функции, но в данном случае предполагалось, что задача будет решена за пару минут, оказалось нет, пропустил момент с девяткой)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
28.11.2020, 13:28
Помогаю со студенческими работами здесь

Шахматы на пайтоне
Хочу написать шахматы на пайтоне. Код прилагаю ниже. Как вынести фигуры в отдельный класс от Example? import sys from...

Шахматы и натуральные числа
Поле шахматной доски определяется парой натуральных чисел, каждое из которых не превосходит восьми: первое число—номер вертикали (при...

Сделал шахматы: прошу критики
Я - начинающий программист-самоучка, программа в архиве - моя первая более-менее серьезная работа, и я хочу чтобы опытные люди указали мне...

Шахматы. Соединить воедино классы
Требуется создать игру при помощи классов и необязательно, но можно использовать библиотеку Tkinter.У меня есть уже скажем...

Шахматы
Есть код пайтона для шахмат на ткинтере, не выводит. Хз почему:(. Помогите люди добрые, и скажите где я ошибся. from tkinter import * ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
Сумматор с применением элементов трёх состояний.
Hrethgir 26.03.2026
Тут. https:/ / fips. ru/ EGD/ ab3c85c8-836d-4866-871b-c2f0c5d77fbc Первый документ красиво выглядит, но без схемы. Это конечно не даёт никаких плюсов автору, но тем не менее. . . всё может быть. . .
Автозаполнение реквизитов при создании документа
Maks 26.03.2026
Программный код из решения ниже размещается в модуле объекта документа, в процедуре "ПриСозданииНаСервере". Алгоритм проверки заполнения реализован для исключения перезаписи значения реквизита,. . .
Команды формы и диалоговое окно
Maks 26.03.2026
1. Команда формы "ЗаполнитьЗапчасти". Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. В качестве источника данных. . .
Кому нужен AOT?
DevAlt 26.03.2026
Решил сделать простой ланчер Написал заготовку: dotnet new console --aot -o UrlHandler var items = args. Split(":"); var tag = items; var id = items; var executable = args;. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru