Обучение по c#

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

основатель — Волосатов Евгений Витольдович
Робот Шарп опять работает.
Open shop Итератор

Итератор

На этом курсе мы познакомимся с интерфейсами IEnumerable + IEnumerator.
На примере решения задачи разложения числа на простые множители
мы будем создавать итератор, который будет перебирать простые числа.

Содержание курса
+ создание класса по интерфейсу IEnumerable
+ создание класса по интерфейсу IEnumerator
+ подробное объяснение, зачем нужно два класса.
+ использование yield для удобной реализации итератора.
+ создание итератора через функцию, не создавая спец. класса.

9 миниуроков.
1 час 22 минут.
Доступ на 15 дней.


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

# Название видеоурока Видео / Тесты Решило Рейтинг Доступ
1 Итератор. Разложение числа на простые множители. 00:09:22
1 тест
131 чел. ★ 4.9 Done
  На этом уроке мы создадим очевидный алгоритм,
который будет раскладывать число на просты множители.
Отчёт отправил: 10080. FireWolf Выполнено за 1 час. 26 мин. [Показать отчёт]
Научился: Вводный урок. Пока ничего нового. Вопрос: а зачем перебирать все числа вплоть до number? Достаточно до number / 2. 
2 Итератор. Создание пустого итератора. 00:11:21
118 чел. ★ 4.8 Done
  На этом уроке мы подберём ключ к циклу foreach.
создадим класс, который позволит создать свой алгоритм
для перебора значений в обычном цикле foreach.

Нaпиши, что такое итератор, своими словами.
Отчёт отправил: 10080. FireWolf Выполнено за 32 мин. [Показать отчёт]
Научился: Пока всё известно, но повторить основы не помешает :) Итератор это набор методов, к которым можно обратиться для обхода коллекции. Необходимо в частности для работы foreach. 
3 Итератор. Перебор чисел в итераторе. 00:09:04
113 чел. ★ 4.9 Done
  На этом уроке мы добавим в созданный класс перебор чисел.
Начнём с двойки и будем его всё время увеличивать "до бесконечности".
В конце урока добавим ограничение, чтобы итератор останавливался.
Отчёт отправил: 10080. FireWolf Выполнено за 1 час. 1 мин. [Показать отчёт]
Научился: Повторяем азы. 
4 Итератор. Перебор простых чисел. 00:10:28
1 тест
111 чел. ★ 4.9 Done
  На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл
только простые числа, как и было задуманно изначально.
Отчёт отправил: 10080. FireWolf Выполнено за 1 час. 18 мин. [Показать отчёт]
Научился: Полезно было вспомнить разницу между implicit и explicit реализациями интерфейса и интересные возможности для обращения к строкам как к IConvertible. 
5 Итератор. Зачем нужно два класса 00:16:21
1 тест
99 чел. ★ 4.9 Done
  На этом уроке мы разберёмся, зачем всё-таки нужно два класса
один для создания итератора, второй для его использования.
Для демонстрации напишем программу, которая выведет
на экран таблицу умножения простых чисел.
Отчёт отправил: 10080. FireWolf Выполнено за 2 час. 45 мин. [Показать отчёт]
Научился: Хорошее объяснение того, почему надо разносить IEnumerable и IEnumerator по разным классам. Кстати, конструкцию: long primeMax = -1; public Primes() { }; public Primes(long pMax) {     primeMax = pMax }; Можно заменить на: long primeMax; public Primes (long pMax = -1) => primeMax = pMax; 
6 Итератор. Волшебное слово yield. 00:11:03
2 теста
97 чел. ★ 4.9 Done
  На этом уроке мы узнаем, как упростить создание итератора.
Для этого достаточно просто написать нужный нам цикл,
внутри которого воспользоватся волшебным словом yield.

Отчёт отправил: 10080. FireWolf Выполнено за 4 час. 26 мин. [Показать отчёт]
Научился: yield это синтаксический сахар для автоматической реализации IEnumerator в котором хранится состояние перечисления. 
7 Итератор. Список простых чисел. 00:08:42
92 чел. ★ 5 Done
  На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка,
который будет постепенно, по мере необходимости, пополняться новыми простыми числами.

Отчёт отправил: 10080. FireWolf Выполнено за 39 мин. [Показать отчёт]
Научился: У меня всегда были проблемы с пониманием математической логики и формул :( Суть yield ясна, но не смогу вот так легко создать логику для поиска простых чисел... 
8 Итератор. Один метод вместо классов. 00:06:19
90 чел. ★ 4.9 Done
  На этом уроке мы увидим, что класс, оказывается, создавать не обязательно.
Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов,
и потом его можно использовать через обычный foreach в любом месте программы.
Вся прелесть в том, что перебор элементов происходит по мере необходимости.

Отчёт отправил: 10080. FireWolf Выполнено за 24 мин. [Показать отчёт]
Научился: Лаконичный и красивый алгоритм, а yield скрывает много работы, которую зав авс делает компилятор :) 
9 ФИНАЛЬНЫЙ УРОК без видео
77 чел. ★ 4.9 Done
  Поздравляю с окончанием курса!
Оставь, пожалуйста, отзыв о курсе.

Какой курс ты будешь проходить следующим?
Отчёт отправил: 10080. FireWolf Выполнено за 18 мин. [Показать отчёт]
Научился: Показана польза от использования конструкции yield но, возможно, стоило более подробно разобрать алгоритм поиска простых чисел. А то немного смешано получилось: то поиск простых чисел, то польза от замены IEnumerator на yield и в результате нет ощущения что и то и то разобрано достаточно подробно. Но это был вебинар, а не специально записанный курс, так что некоторая сжаточть изложения вполне понятна :) Следующим посмотрю комбинаторику или функциональное программирование. 
10 VIP. Оптимизация поиска простых чисел 01:19:28
1 тест
41 чел. ★ 5 Done
  Пишем функцию для поиска простых чисел и
поэтапно оптимизируем её в двух направлениях.
Отчёт отправил: 10080. FireWolf Выполнено за 1 день 11 час. 3 мин. [Показать отчёт]
Научился: А вот и варианты алгоритма поиска. Стоило бы сразу в лписании первого урока упомянуть, что алгоритм поиска простых чисел будет разбираться в вип-уроке :) Полезный урок, так как я особо не задумывался о поиске простых чисел. Добавлять решето Эртосфена и Аткина не стал, так как не представляю, как эти алгоритмы можно подружить с ограничением по времени выполнения: они же работают с заполненной коллекцией чисел, а не производят проверку для каждого числа. 
  Итого:   10 видеоуроков 2 час. 42 мин.
6 тестов
41 чел. ★ 4.91  
  Финалисты:   Иван Воронин,   Елена,   Артём,   Новопашин Владимир,   Алексей В.,   Фомичева Наталья,   Rita,   Станислав,   Neverwinter 2,   Permitin Alexey,   aleksey-k,   Николай Денисов,   Денис,   Bazel,   kalobyte,   Yefim,   Tekashnik,   Алексей Малышев,   Sergio,   Роман,   konstantin,   Сергей Стефаненко,   chokayes,   ser2018,   vip,   Виктор,   Дмитрий,   Максим Лапшинов,   FireWolf,   Слава,   Денис,   Александр,   New programist,   no name,   Deep Network,   Кирилл,   Max,   Kitsuneco,   Дмитрий,   Anatoli,   MaxB .

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





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

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

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

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


Научился: Использованию интерфейсов со страшными названиями IEnumerable и IEnumerator. И супер-мощному yield ), последний урок вообще хирургический, все без сожаления повырезали и упростили, класс. В общем, суперский курс Итератор. Вместо того, чтобы ждать пока у вас заполнится массив и т.д. вы сразу на месте используете элементы. Это ж круто и суперэффективно. Кто еще не прошел всем советую срочно все бросить и пройти его, чтобы разобраться с итерацией, не смотрите на цену, у него цена неадекватная содержанию! Следующий курс у меня как раз коллекции в Java, хочу сравнить. )



Научился: Хороший курс который положит базу для дальнейшего изучения данной темы. От простого к сложного были объяснены основные моменты работы итератора. Дальше буду еще разбираться как все работает чтоб окончательно понять. Хочется все разложить по полочкам. Спасибо ЕВ за проделанную работу.
Трудности: Сложностей не возникло.