На этом уроке мы добавим в игру Крестики-Нолики искуственный интеллект. Мы напишем алгоритм, который будет искать наилучший ход для позиции.
Дата отправки отчёта:
25 апреля 2016 г.
Задание выполнено: за
3 час. 50 мин.
Чему научился:
Повторил работу с STL алгоритмами поиска, подсчета элементов, созданием своего функтора поиска выигрышной линии.
Что было сложным:
1) Реализовать асинхронный выбор ячейки для Игрока-Человек. 2) Выиграть у компьютера игрой ноликами (второй скриншот).
Комментарии:
Логика работы игры Крестики-Нолики была написана в прошлом уроке. Мне не хотелось менять, ломать, модифицировать работающий код. По сути, нет разницы кто играет, человек или компьютер, правила игры от этого не меняются. Главное, чтобы игрок мог посмотреть на игровое поле, оценить ситуацию и сообщить координаты хода. Поэтому искал решение, пришел к похожему варианту, предложенному во второй части курса ООП. Выделил интерфейс Игрок, реализовал его в двух классах Игрок-Человек и Игрок-Компьютер. Добавил новую оболочку для Логики, которая принимает ввод от Игрока и перенаправляет его Логике. Здесь были некоторые проблемы со вводом от Игрока-Человека, так как он асинхронный. Алгоритм Компьютера не менял, взял из урока.
Результатом доволен, понравилось играть с компьютером :)
Спасибо, Евгений Витольдович, я крестиками довольно быстро обыграл компьютер (на первом скриншоте), а вот ноликами в основном ничья, бывало и проигрывал:) В дополнении реализовал игру компьютера против компьютера, было интересно посмотреть на их ходы.
Отчёт оценивали: Посетитель+1
Начинаем практику по языку C#
Чтобы стать хорошим программистом — нужно писать программы.
На нашем сайте очень много практических упражнений.
После заполнения формы ты будешь подписан на рассылку
«C# Вебинары и Видеоуроки»,
у тебя появится доступ к видеоурокам и консольным задачам.
Несколько раз в неделю тебе будут приходить письма —
приглашения на вебинары, информация об акциях и скидках,
полезная информация по C#.