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

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

основатель — Волосатов Евгений Витольдович
Поздравляю с 1 сентября! Система начисления Байтов работает.
Open shop Итератор

Итератор

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

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

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


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

# Название видеоурока Видео / Тесты Решило Рейтинг Доступ
1 Итератор. Разложение числа на простые множители. 00:09:22
1 тест
138 чел. ★ 4.9 Done
  На этом уроке мы создадим очевидный алгоритм,
который будет раскладывать число на просты множители.
Отчёт отправил: 20111. Deep Network Выполнено за 34 мин. [Показать отчёт]
Научился: Пока ничему. В моем понимании итератор используется для реализации механизма обхода в пользовательских коллекциях. Получается дальше будем создавать пользовательскую коллекцию которая будет содержать набор простых чисел. Пока еще не понял задумки, интересно что будет дальше. 
Сложности: Сложностей не возникло. 
2 Итератор. Создание пустого итератора. 00:11:21
1 тест
125 чел. ★ 4.8 Done
  На этом уроке мы подберём ключ к циклу foreach.
создадим класс, который позволит создать свой алгоритм
для перебора значений в обычном цикле foreach.

Нaпиши, что такое итератор, своими словами.
Отчёт отправил: 20111. Deep Network Выполнено за 26 мин. [Показать отчёт]
Научился: В конце тоже такой вопрос  возник, а в чем фишка с двумя классами. Смотрю дальше... 
Сложности: Трудностей не возникло 
3 Итератор. Перебор чисел в итераторе. 00:09:04
120 чел. ★ 4.9 Done
  На этом уроке мы добавим в созданный класс перебор чисел.
Начнём с двойки и будем его всё время увеличивать "до бесконечности".
В конце урока добавим ограничение, чтобы итератор останавливался.
Отчёт отправил: 20111. Deep Network Выполнено за 18 мин. [Показать отчёт]
Научился: Пока все понятно, вопрос о двух классах еще открыт, смотрю дальше... 
Сложности: Сложностей не возникло. 
4 Итератор. Перебор простых чисел. 00:10:28
2 теста
118 чел. ★ 4.9 Done
  На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл
только простые числа, как и было задуманно изначально.
Отчёт отправил: 20111. Deep Network Выполнено за 38 мин. [Показать отчёт]
Научился: Все понятно. 
Сложности: Трудностей не возникло. 
5 Итератор. Зачем нужно два класса 00:16:21
1 тест
106 чел. ★ 4.9 Done
  На этом уроке мы разберёмся, зачем всё-таки нужно два класса
один для создания итератора, второй для его использования.
Для демонстрации напишем программу, которая выведет
на экран таблицу умножения простых чисел.
Отчёт отправил: 20111. Deep Network Выполнено за 54 мин. [Показать отчёт]
Научился: Теперь понятно зачем 2 класса.  
Сложности: Трудностей не возникло, хотя понять получилось не сразу. 
6 Итератор. Волшебное слово yield. 00:11:03
3 теста
104 чел. ★ 4.9 Done
  На этом уроке мы узнаем, как упростить создание итератора.
Для этого достаточно просто написать нужный нам цикл,
внутри которого воспользоватся волшебным словом yield.

Отчёт отправил: 20111. Deep Network Выполнено за 2 час. 16 мин. [Показать отчёт]
Научился: Ключевое слово yield генерирует итераторы для обхода коллекций. По сути можно и не наследовать никаких интерфейсов, ключевое слово yield само для нас создаст итератор. yeild return как бы добавляет элементы пока выполняется условие MoveNext => true, а потом возвращает всю коллекцию в цикл, yield break говорит что MoveNext = false и можно прекратить обход в цикле так как в коллекции нет больше элементов для обхода. Как-то так, в какой-то момент мне казалось что я понял как все работает,  а сейчас вроде понятно, а вроде и нет, немого запутался) Из урока про yield вообще ничего не понял, смотрел и читал дополнительно. 
Сложности: Понять как работает yield. Вроде немного понял, но не до конца.  
7 Итератор. Список простых чисел. 00:08:42
1 тест
98 чел. ★ 5 Done
  На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка,
который будет постепенно, по мере необходимости, пополняться новыми простыми числами.

Отчёт отправил: 20111. Deep Network Выполнено за 33 мин. [Показать отчёт]
Научился: О_о, возвращается не коллекция целиком, теперь стало немного понятней как все работает. 
Сложности: Чем дальше тем запутанней. Вроде как пока понятно. 
8 Итератор. Один метод вместо классов. 00:06:19
95 чел. ★ 4.9 Done
  На этом уроке мы увидим, что класс, оказывается, создавать не обязательно.
Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов,
и потом его можно использовать через обычный foreach в любом месте программы.
Вся прелесть в том, что перебор элементов происходит по мере необходимости.

Отчёт отправил: 20111. Deep Network Выполнено за 41 мин. [Показать отчёт]
Научился: Понял как можно еще упростить код. 
Сложности: Трудностей не возникло. 
9 ФИНАЛЬНЫЙ УРОК без видео
82 чел. ★ 5 Done
  Поздравляю с окончанием курса!
Оставь, пожалуйста, отзыв о курсе.

Какой курс ты будешь проходить следующим?
Отчёт отправил: 20111. Deep Network Выполнено за 30 мин. [Показать отчёт]
Научился: Хороший курс который положит базу для дальнейшего изучения данной темы. От простого к сложного были объяснены основные моменты работы итератора. Дальше буду еще разбираться как все работает чтоб окончательно понять. Хочется все разложить по полочкам. Спасибо ЕВ за проделанную работу. 
Сложности: Сложностей не возникло. 
Видеообзор: kc9QvxXnR94
10 VIP. Оптимизация поиска простых чисел 01:19:28
1 тест
44 чел. ★ 5 Done
  Пишем функцию для поиска простых чисел и
поэтапно оптимизируем её в двух направлениях.
Отчёт отправил: 20111. Deep Network Выполнено за 1 день 9 час. 58 мин. [Показать отчёт]
Научился: Хороший урок, с поэтапной оптимизацией алгоритма, хочется видеть как можно больше уроков где подробно и поэтапно все показано, а то вот код и так он работает))). Сложностей как таковых не возникло. Наверно самое полезное что было - это подход к написанию кода (методы проверки и измерения продуктивности методов) 
Сложности: Сложностей не возникло. 
  Итого:   10 видеоуроков 2 час. 42 мин.
10 тестов
44 чел. ★ 4.92  
  Финалисты:   Иван Воронин,   Елена,   Артём,   Новопашин Владимир,   Алексей В.,   Фомичева Наталья,   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,   София,   Tom,   Tim .

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





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

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

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

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


Замечательный курс чтобы понять как искать ошибки в программах решать сложные задачи. Буду изучать дальше.


Научился: Курс понравился! Интересная информация с практикой по итератору!
Спасибо за курс!