# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 |
![]() |
1 тест |
|||
Мы начинаем серию видеоуроков по созданию алгоритма решения головоломки Судоку. Ваша задача - разобраться с правилами этой игры. найти/распечатать бумажное (!) Судоку. Решить его ручкой или карандашом. Сфоткать решение и приложить к отчёту. Отчёт отправил: 11589. Yefim Выполнено за 38 мин. [Показать отчёт] Научился: Всё знакомо. Сложности: Не было возможности распечатать исходный лист. Пришлось решать в он лайне |
|||||
2 | Сетка для цифр |
1 тест |
|||
На этом уроке мы создадим класс Sudoku, опишем в нём две константы и создадим функцию для отображения сетки для цифр. Отчёт отправил: 11589. Yefim Выполнено за 12 час. 27 мин. [Показать отчёт] Научился: Подготавливать поле игры Сложности: Всё ясно |
|||||
3 | Печать цифр в таблице |
|
|||
На этом уроке мы добавим метод для добавления цифр в наш Судоку. Также напишем функцию для отображения цифр в консольном экране. И свяжем их через использование делегата. В конце урока заполним наше поле случайнмыи цифрами. Отчёт отправил: 11589. Yefim Выполнено за 1 час. 29 мин. [Показать отчёт] Научился: Отображать цифры в консольном экране с использованием делегата. Сложности: Всё ясно. |
|||||
4 | Проверка правил игры |
1 тест |
|||
На этом уроке мы наконец-таки начнём писать алгоритм. В метод PlaceDigit() мы запрограммируем проверку правил игры. Числа должны быть из верного диапозона, они не должны повторяться в строчке, в столбце и в квадрате. Под занавес мы сгенирируем случайную матрицу по всем правилам судоку. Не факт, что её можно будет решить, и что решение будет единственным. Отчёт отправил: 11589. Yefim Выполнено за 1 час. 7 мин. [Показать отчёт] Научился: В самом верхнем окне представлены данные без проверки. В остальных с проверкой. Видно, что проверка реально работает. Сложности: Вопрос: В классе Sodoku мы часто используем Sodoku.sqr, хотя могли бы ограничиться только sqr, тем более что это константа. В чем преимущество такого подхода? |
|||||
5 | Загрузка головоломки с интернета |
1 тест |
|||
На этом уроке мы напишем функцию для загрузки Судоку с интернет-сайта. Через буфер обмена содержимое страницы будет размещено в текстовом файле. Алгоритм будет его анализировать и добавлять в матрицу класса Sudoku. Отчёт отправил: 11589. Yefim Выполнено за 5 час. 43 мин. [Показать отчёт] Научился: Создавать функцию для загрузки информации в свою программу с интернет-сайта. Отличный, великолепный урок!!! |
|||||
6 | Идея алгоритма - 81 цикл |
|
|||
На этом уроке мы вручную проработаем алгоритм поиска в глубь с возвращением. Твоя задача - не аналитически решить судоку, а программно, применяя описанный на уроке алгоритм. Отчёт отправил: 11589. Yefim Выполнено за 15 час. 51 мин. [Показать отчёт] Научился: Узнал об алгоритме 81. Подозреваю, что в некоторых случаях алгоритм будет работать медленно. Сложности: Пройти вручную алгоритм |
|||||
7 | Рекурсивная функция поиска |
1 тест |
|||
На этом уроке мы напишем рекурсивную функцию NextDigit(), которая и будет заниматься поиском решения головоломки. Способы оптимизации алгоритма поиска решения: https://habrahabr.ru/post/173795/ Отчёт отправил: 11589. Yefim Выполнено за 2 час. 56 мин. [Показать отчёт] Научился: Великолепный урок! Рекурсия божественна!!! Сложности: --- |
|||||
8 | Сохранение ответа |
1 тест |
|||
На этом уроке мы напишем функцию для сохранения решения головоломки в текстовый файл.
Отчёт отправил: 11589. Yefim Выполнено за 2 час. 45 мин. [Показать отчёт] Научился: Записывать информацию в текстовый с помощью StreamWriter Сложности: Когда увидел расхождение своего решения с предложенным на сайте, заметил свою ошибку (в маленьком квадрате появлялась 1 дважды). Обнаружил ошибку в своём коде в функции PlaceDigit. После исправления - решения совпали. |
|||||
9 | Генерация головоломок |
|
|||
На этом уроке мы напишем алгоритм для формирования Судоку-головоломок, поэкспериментируем с генератором случайных полей. Отчёт отправил: 11589. Yefim Выполнено за 2 час. 3 мин. [Показать отчёт] Научился: Реализовывать Генератор Случайного поля из N чисел. Сложности: Выбрать следующий курс |
|||||
10 | ФИНАЛЬНЫЙ УРОК |
без видео |
|||
Поздравляю с завершением этого видеокурса! Запиши и опубликуй видеообзор созданной программы. Напиши, какой курс будешь проходить следующим. |
|||||
11 | VIP. Модульное тестирование |
|
|||
На этом уроке мы познакомимся с модульным тестированием. Мы напишем небольшой калькулятор, в который добавим проект для модульного тестирования, и покажем, как это всё работает, как это нужно использовать. |
|||||
Итого: 11 видеоуроков |
2 час. 54 мин. 6 тестов |
15 чел. | |||
Финалисты: zhikharevav, Максим, Новопашин Владимир, Максим Лапшинов, Волнухин Владимир, Tekashnik, Александр, Николай Денисов, Иван, no name, Александр, Anatoli, Freud, Татьяна, MaxB . |