Курсы по программированию

Формула программиста
основатель — Волосатов Евгений Витольдович

Морской Бой / Олимпиада - Самый лучший алгоритм

  • На участие в олимпиаде было прислано 10 работ.
    В этом видео мы проводим тестирование всех программ.
    Домашнее задание - составить словесный алгоритм ИИ.
  • Дата отправки отчёта: 15 марта 2016 г.
  • Задание выполнено: за 1 час. 00 мин.
  • Чему научился: Изучил алгоритмы поиска кораблей
  • Что было сложным: Выбрать один алгоритм.
  • Комментарии: Хоть у Orange самый быстрый алгоритм, однако более понятным и простым решением для меня оказалось решение Елены Вставской. Сразу стало всё интересно и понятно.
    Чем-то напоминает поиск каждой 4клетки решето Эратосфена:)
  • Оценка видео-уроку:
Отчёт от 6925 за Морской Бой / Олимпиада - Самый лучший алгоритм




Оцени работу

 
Сохранить страницу:

24. Оля
Оля
ответить
→  Артём  # Морской Бой / Олимпиада - Самый лучший алгоритм / 2016-03-16 12:19

Артем, мне вот тоже больше всех понравился алгоритм Елены, и пока я думала как раз на этом уроке и зависла в этом курсу, а ты Молодец! :)


2146. Иван
Иван
ответить
→  Артём  # Морской Бой / Олимпиада - Самый лучший алгоритм / 2016-03-15 20:29

Прекрасно! Попробуй сам написать этот алгоритм. Самостоятельность очень нас продвигает!


  • Отчёт оценивали:
    1Евгений Волосатов+1   9427Иван Алексеевич+1   689Igorenzia+1   5026Екатерина+1   7645Александр Львович+1   4992Николай+1   8886Михаил Ермишин+1   6452Кирилл Шмойлов+1   1537Сергей+1   459Сергей Сергеевич+1   9288Pučko Antonina+1   9323Алексей0   4699Сергей Витальевич+1   2146Иван+1   4467Alcatraz+1   5760Мариша +1   9634Лис Бесчувственный0   9263Андрей Н.0   4395Денис+1   9286Petuško Julija+1   9289Voskoboinikova Ana +1   3506Алексей|BrisK|Кривицкий+1   24Оля+1  

Начинаем практику по языку C#




Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

После заполнения формы ты будешь подписан на рассылку «C# Вебинары и Видеоуроки», у тебя появится доступ к видеоурокам и консольным задачам.

Несколько раз в неделю тебе будут приходить письма — приглашения на вебинары, информация об акциях и скидках, полезная информация по C#.

Ты в любой момент сможешь отписаться от рассылки.
Научился: Пока что ничему. Как правильно расставлять корабли и как их ловить давно известно, а кода здесь не было. Но планирую повнимательнее изучить сам код победителей, чтобы увидеть как вообще задавать выстрелы и определять зоны, в которые стрелять уже не надо.
Трудности: Просто нет необходимых знаний для переноса алгоритма из головы в программу. Лучший алгоритм у Оранжа 2775. У Елены 4004 отсутствует рандом, у нее всегда одинаковое количество ходов тратится на одну и ту же расстановку, минимум = среднему = максимуму. Она методично проходит по А4 - А8 - Б1 - Б5 и т.п. - ловит четырехпалубный. Затем так же методично проходит А2 - А6 - А10 - Б3 и т.п. и ловит двухпалубные. А затем просто проходит и методично добивает остальных. Но такой алгоритм очень предсказуем и можно просто добиться такой расстановки против нее, что количество ходов всегда будет 80, достаточно поместить однопалубный в самый конец сетки. Например, К9.
Думаю, что не совсем правильно начинать ловить корабли от левого верхнего угла. Люди больше тяготеют к расстановке кораблей внизу и справа. И при расстановке они ставят корабли так, чтобы не попасть сразу под ходы А4, А8, Б1, Б5 и т.п. Думаю, что нужно начинать выстрелы с клеток К4, К8, З10, Г10 и далее по кругу на вертикаль А и горизонталь 1. Затем пройти по спирали до центра. Аналогично пройти шагом 2 и выловить все корабли, кроме одиночных. Когда останутся только одиночные, то первые 3 выстрела в те клетки, которые имеют максимальное количество "неоткрытых" соседей, а 4-й - в клетку с минимальным количеством соседей. Необходимое соотношение выстрелов в наиболее выгодные клетки с выстрелами в клетки, у которых все соседние уже открыты, нужно определять опытным путем.
Научился: Искать разные способы решения поставленной задачи. Сравнивать эффективность разных алгоритмов с помощью C#. Эффективно играть в Морской бой. :-)
Трудности: Придумать свой эффективный алгоритм, отличающийся от предложенных. Пока не удалось. Предположения: - задействовать random, чтобы защититься от искусственно подобранных "контррасстановок"; - перед каждым выстрелом находить возможное расположение кораблей; - стремиться к равномерному обстрелу вертикалей и горизонталей; - возможно, использовать заготовленные шаблоны совместно с random.
Понравился алгоритм Orange. Свой пока сделаю простым. 1. Создадим матрицу 10 × 10, в которой номерами установим порядок обстрела всех точек. - Правило обстрела выберем по диагоналям с постепенно уменьшающимся интервалом. - Оставшиеся часть матрицы заполним, отразив первую зеркально. 2. Будем последовательно перебирать в заданном порядке я чейки для обстрела. 3. Стреляем, если ячейка имеет статус "неизвестно". 4. Если ранили, то добиваем корабль. - проверяем ячейки по горизонтали и по вертикали от раненой; - если снова попали, запоминаем направление, а соседние ячейки в другом измерении помечаем "мимо";; - если после этого промах - добиваем в обратную сторону;