Изучение c# на примерах

Формула программиста

основатель — Волосатов Евгений Витольдович

Клуб формулистов - Ежемесячная подписка

Вступление в Клуб Формулистов на выгодных условиях для НОВЫХ участников.

После взноса  999  499 руб. вы получите подписку
в Клуб Формулистов на 30 дней и 256 байт для быстрого старта.
Байты используются для открытия более одного урока в день, по 50 байт за урок.

Стоимость 1 дня за первый месяц: всего 16 рублей.

Первый взнос - 499 руб./30 дней.

Через 30 дней будет списано 3,000 2,400 руб.
за продление подписки в Клуб на 30 дней + подарок 512 байт.

Так будет продолжаться каждые 30 дней, пока вы не отмените подписку.
Средства будет автоматически считываться с вашей карты.
Вы в любой момент сможете отказаться от продления Клуба.

Только ДО КОНЦА НЕДЕЛИ -
-50% скидка на первый взнос, всего 499 (вместо 999) рублей!
-20% скидка на ЕЖЕМЕСЯЧНЫЙ платёж!
Всего 2400 руб/месяц (вместо 3000 руб/месяц), или 80 руб./день - цена чашки кофе.


Стоимость 1 дня: 80 руб.

Хочу вступить!

Также есть другие варианты оплаты участия в КФ:

Билет в клуб формулистов на ...
30+ дней | 60 дней | 150 дней | 380 дней | 1000 дней

Внимание!
Стоимость участия в Клубе формулистов увеличивается 1 числа каждого месяца на 100 рублей.
При оформления подписки стоимость остаётся постоянной, пока подписка не будет отменена.







Первый взнос - 499 руб./30 дней + 500 байт.
Последующие взносы - 3,000 2400 руб./месяц + 512 байт.



Список уроков | фото | видео

# Название видеоурока Видео / Тесты Решило Рейтинг Доступ
1 FREE Что такое Dancing Links 00:08:36
42 чел. ★ 4.9 Done
  В этой серии уроков мы познакомимся с гениальным алгоритмом X Дональда Кнута - Dancing Links.

Этот алгоритм можно применять для решения самых разных комбинаторных задач, например,
разложение Пентамимо, решение Судоку, размещение ферзей и так далее.

Статья Дональда Кнута: https://arxiv.org/pdf/cs/0011047v1.pdf
Обзорная статья на Хабре:  https://habrahabr.ru/post/194410/
Отчёт отправил: 10558. Иван Воронин Выполнено за 15 мин. [Показать отчёт]
Научился: Повторил что такое Dancing Links 
Сложности: найти время 
Комментарии: Алгоритм сравнения матриц через линейное представление отличная идея, нашёл в сети картинку, где Судоку решали подобным способом, думаю можно будет записать либо Вип урок либо продолжение уроков для курса Судоку, у нас же есть курс по Сапёру, он вообще состоит из 3 частей. С ферзями тоже этот алгоритм будет работать, я думаю этот алгоритм удобен для проверки корректности созданных карт в Сокобане =) 
2 Работа алгоритма 00:23:48
34 чел. ★ 4.8 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы пошагово рассмотрим статью на Хабре.

Отчёт отправил: 10558. Иван Воронин Выполнено за 40 мин. [Показать отчёт]
Научился: Повторил разбор полётов на Хабре 
Сложности: найти время 
Комментарии: На скриншоте видно состояние матрицы каждую итерацию. Использовал тёмный оттенок при сохранении фигуры и светлые оттенки того же цвета для выявления пересечений с ней. Решил так же рассмотреть ситуацию из урока, где первую фигуру выбрали D. Таким образом к тому моменту, когда выбрали вторую фигуру и отсеяли пересечения с ней, осталось всего две фигуры, которые ни с чем не пересекаются, а просто сохраняются и вуаля, решение найдено. з.ы. урок отличный, очень полезно проработать алгоритм для лучшего понимания. з.з.ы. добавил описание цвета в виде легенды внизу скриншота.  
3 Двусвязный список с удалением 00:10:47
29 чел. ★ 4.8 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы пошагово рассмотрим статью автора данного алгоритма
и рассмотрим пошаговое удаление и возвращение элемента.

Отчёт отправил: 10558. Иван Воронин Выполнено за 1 час. 10 мин. [Показать отчёт]
Научился: Повторил алгоритм удаление/восстановления элементов из списка. 
Сложности: найти время 
Комментарии: Отличный урок, очень хорошо продемонстрирован алгоритм удаления/восстановления элементов списка. Решил реализовать это всё в Excel для большей наглядности. 
4 Расширение хоровода 00:24:09
28 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы наконец приступим к реализации двусвязного списка на языке C#.

Отчёт отправил: 10558. Иван Воронин Выполнено за 50 мин. [Показать отчёт]
Научился: Реализации динамичного списка вместо статичного массива. 
Сложности: найти время 
Комментарии: Отличный урок, всё гениальное - просто!!! идём дальше. 
5 Заголовки столбцов 00:12:18
28 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы реализуем перемещение вверх/вниз для реализации четырёх-связного списка,
так же создадим класс Header(), чтобы знать в каком столбце мы находимся.

Отчёт отправил: 10558. Иван Воронин Выполнено за 45 мин. [Показать отчёт]
Научился: Созданию динамического четырёх-связного списка с использованием заголовка как указателя на текущую колонку. 
Сложности: найти время 
Комментарии: Урок можно было разбить на две части, создание класса Header() вынести в отдельный и завершить его, чтобы не было неопределённости в конце урока =) В любом случае заготовка отличная, идём дальше. 
6 Единичная матрица 00:25:02
27 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке, используя созданный ранее четырёх-связный список, мы
добавим необходимые нам элементы для дальнейшем работы с ними.

Отчёт отправил: 10558. Иван Воронин Выполнено за 27 мин. [Показать отчёт]
Научился: Повторил пройденное 
Сложности: найти время 
Комментарии: Заполнили матрицу элементами для примера, проверили работоспособность алгоритма в полевых условиях, осталось добавить функционал перебора возможных вариантов. Чем дальше, тем интереснее. 
7 Как ссылки пошли впляс 00:21:16
26 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы реализуем заготовку функции Dance() в классе Dance().

Отчёт отправил: 10558. Иван Воронин Выполнено за 17 мин. [Показать отчёт]
Научился: Закреплению полученного материала на вебинаре. 
Сложности: найти время 
Комментарии: Отличная реализация алгоритма, но нужно идти дальше, чтобы завершить его окончательно и протестировать в полевых условиях. 
8 Открытие/закрытие столбцов 00:32:15
26 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы доработает функции AddRow() и Dance() в классе Dance().
Так же реализуем функции Cover/Uncover().

Отчёт отправил: 10558. Иван Воронин Выполнено за 33 мин. [Показать отчёт]
Научился: Закрепил пройденное на вебинаре. 
Сложности: найти время 
Комментарии: Отлично, всё просто супер, ошибка которая возникла с середины урока у меня не проявилась, так как был на вебинаре и успевал за Игромистром, но писал сам, повторяя идеи и сразу написал так как надо. Поэтому искать ошибку не пришлось =) 
9 Фигуры из пентамимо 00:18:17
25 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы приступаем к решению олимпиадной задачи: Пентамино,
заполнив массив всеми вариантами расположения фигур.

Отчёт отправил: 10558. Иван Воронин Выполнено за 20 мин. [Показать отчёт]
Научился: Повторил пройденное 
Сложности: найти время 
Комментарии: Отличная идея хранения вариантов расположения фигур в массиве. Осталось за малым, реализовать алгоритм перебора вариантов расположения фигур. 
10 Фигуры в консоли 00:15:00
21 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы решили реализовать возможность отображения фигур в консоли,
чтобы в дальнейшем видеть что происходит в процессе работы алгоритма.

Отчёт отправил: 10558. Иван Воронин Выполнено за 31 мин. [Показать отчёт]
Научился: Повторил пройденное 
Сложности: найти время 
Комментарии: Вывел все фигур по диагонали. Отличный урок, очень не хватало визуализации происходящего =) 
11 Матрица Пентагона 00:15:56
24 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы завершим реализацию функции поиска решения Пентамино.

Отчёт отправил: 10558. Иван Воронин Выполнено за 32 мин. [Показать отчёт]
Научился: Закрепил знания полученный на вебинаре. 
Сложности: найти время 
Комментарии: Отличный урок, интересная реализация алгоритма, осталось дождаться окончания его работы =) з.ы. Однозначно требуется оптимизация, чем и займёмся на след. уроке. 
12 Пентагон в деталях 00:09:41
21 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы воспользуемся функцией Show() в классе Figure()
для визуализации генерации всех вариантов расположения фигур Пентамино.

Отчёт отправил: 10558. Иван Воронин Выполнено за 27 мин. [Показать отчёт]
Научился: Повторил пройденное 
Сложности: найти время 
Комментарии: Отличный урок, наглядно показано как формируется матрица всевозможных вариантов расположения фигур на поле. Теперь осталось визуализировать поиск решения, чтобы ожидание завершения алгоритма в не оптимизированном виде было более приятным =) 
13 Пентагон ищет решение 00:22:02
19 чел. ★ 4.9 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы визуализируем поиск решения Пентамино с использованием yield.

Отчёт отправил: 10558. Иван Воронин Выполнено за 3 час. 41 мин. [Показать отчёт]
Научился: Закрепил пройденное 
Сложности: найти время 
Комментарии: Добавил поддержку отображения найденных ответов ниже поля перебора относительно друг друга, чтобы не пересекались (проверить можно будет после внедрения оптимизации, так как ждать уж очень долго, хотя и более наглядно). Добавил поддержку полей более 60 клеток (см. скриншот) при этом учитываются дубликаты фигур, цвет фигур, индексация и т.д. все необходимые нюансы. Как видно из скриншота, добавлена поддержка ввода размеров поля через командную строчку, для этого создал батника с необходимыми размерами для тестирования. з.ы. обожаю относительность =) 
14 Десятикратная оптимизация 00:19:36
22 чел. ★ 5 Done
  Мы продолжаем знакомство с гениальным алгоритмом X Дональда Кнута - Dancing Links.
На этом уроке мы оптимизируем наш алгоритм поиска решения Пентамино.

Отчёт отправил: 10558. Иван Воронин Выполнено за 22 мин. [Показать отчёт]
Научился: Закрепил пройденное на вебинаре 
Сложности: найти время 
Комментарии: Отличное завершение не менее гениального алгоритма, геттеры и сеттеры использовал только в том случае, если нужно запретить использование переменных извне, в нашем случае приватного атрибута не устанавливалось для сеттера, поэтому и смысла в них нет, но то, что они так тормозят это жесть, учту на будущее. Знал, что доп. безопасность кода отнимает ресурсы, но в некоторых ситуациях, если алгоритм вылизан эти можно пренебречь в угоду скорости. Очень хотелось реализовать графическую демонстрацию, но времени как всегда нет, в другой раз обязательно реализую. з.ы. что касается ферзей и судоку, до судоку ещё не добрался. а ферзей ещё год назад реализовал, для ферзей этот алгоритм будет кстати, по поводу судоку как доберусь, так скажу свой вердикт, но в любом случае, в сети уже есть реализации танцующего судоку, так что думаю реализовать реально. 
  Итого:   14 видеоуроков 4 час. 18 мин.
17 чел. ★ 4.9  
  Финалисты:   Иван Воронин,   Андрей,   AZANIR,   Алексей Малышев,   Сергей Соколов,   Алексей В.,   Максим Лапшинов,   Spellion,   Tekashnik,   Yefim,   Новопашин Владимир,   Bazel,   Николай Денисов,   Иван,   Дмитрий,   Max,   MaxB .

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





Если вы пришли без приглашения -
введите тысяча двадцать четыре (цифрами).
Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

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

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

Ты в любой момент сможешь отписаться от рассылки.


Научился: Реализации динамичного списка вместо статичного массива.
Отличный урок, всё гениальное - просто!!! идём дальше.


Научился: выводить все варианты перебора на экран понять еще один пример с yield удивил он
спасибо за уроки