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

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

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

Итератор

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

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

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


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

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

Нaпиши, что такое итератор, своими словами.
Отчёт отправил: 11019. Trira Выполнено за 2 дня 5 час. 14 мин. [Показать отчёт]
Научился: создала класс, реализующий интерфейс IEnumerable, создала класс, реализующий интерфейс IEnumerator и объединила оба класса в один. Итератор - (перечислитель) — приложение, предоставляющее доступ к элементам коллекции (контейнера) и навигацию по ним. 
Сложности: не поняла, зачем объединять два класса, если потом их все равно надо будет разделить 
3 Итератор. Перебор чисел в итераторе. 00:09:04
120 чел. ★ 4.9 Done
  На этом уроке мы добавим в созданный класс перебор чисел.
Начнём с двойки и будем его всё время увеличивать "до бесконечности".
В конце урока добавим ограничение, чтобы итератор останавливался.
Отчёт отправил: 11019. Trira Выполнено за 35 мин. [Показать отчёт]
Научился: Добавлено перечисление в класс, сделано ограничение для счетчика. 
4 Итератор. Перебор простых чисел. 00:10:28
2 теста
118 чел. ★ 4.9 Done
  На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл
только простые числа, как и было задуманно изначально.
Отчёт отправил: 11019. Trira Выполнено за 2 дня 1 час. 4 мин. [Показать отчёт]
Научился: Программа переделана так, чтобы класс Primes возвращал в цикл только простые числа.  (добавлен метод bool IsPrime() и доработан метод bool MoveNext() ) 
5 Итератор. Зачем нужно два класса 00:16:21
1 тест
106 чел. ★ 4.9 Done
  На этом уроке мы разберёмся, зачем всё-таки нужно два класса
один для создания итератора, второй для его использования.
Для демонстрации напишем программу, которая выведет
на экран таблицу умножения простых чисел.
Отчёт отправил: 11019. Trira Выполнено за 2 час. 15 мин. [Показать отчёт]
Научился: Предыдущий вариант изменен так, чтобы классы для создания итератора и для его использования описывались отдельно. Измененная программа проверена для примера составления таблицы умножения для простых чисел от 2 до 29 
Сложности: сложно было не запутаться при инициализации экземпляров. В каждом классе определение переменных задается заново, есть повторы кода. Это вносит путаницу. 
6 Итератор. Волшебное слово yield. 00:11:03
3 теста
104 чел. ★ 4.9 Done
  На этом уроке мы узнаем, как упростить создание итератора.
Для этого достаточно просто написать нужный нам цикл,
внутри которого воспользоватся волшебным словом yield.

Отчёт отправил: 11019. Trira Выполнено за 23 час. 50 мин. [Показать отчёт]
Научился: yield создает итератор и позволяет нам не писать отдельный класс когда мы реализуем IEnumerable . C# содержит два выражения использующих yield : yield return <expression> и yield break также можно прочитать про это, перейдя по ссылке https://habr.com/ru/post/311094/ 
7 Итератор. Список простых чисел. 00:08:42
1 тест
98 чел. ★ 5 Done
  На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка,
который будет постепенно, по мере необходимости, пополняться новыми простыми числами.

Отчёт отправил: 11019. Trira Выполнено за 1 день 3 час. 21 мин. [Показать отчёт]
Научился: алгоритм предыдущей программы переписан для списка List<long>  ,  сохраняющего простые числа по мере их нахождения алгоритмом. Работа алгоритма протестирована для числа number = 614889782588491410 
Сложности: отследить границы блоков в программе 
8 Итератор. Один метод вместо классов. 00:06:19
95 чел. ★ 4.9 Done
  На этом уроке мы увидим, что класс, оказывается, создавать не обязательно.
Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов,
и потом его можно использовать через обычный foreach в любом месте программы.
Вся прелесть в том, что перебор элементов происходит по мере необходимости.

Отчёт отправил: 11019. Trira Выполнено за 7 час. 5 мин. [Показать отчёт]
Научился: Еще раз переделана программа нахождения простых чисел. В этот раз класс Primes заменен на метод GetPrimes() как интерфейс IEnumerable , Вообще-то, интерфейс IEnumerable содержит метод, возвращающий перечислитель – GetEnumerator(). Этот метод мы описывали во всех предыдущих вариантах программы. Однако, в последней версии этот метод был модифицирован. Алгоритм стал проще и .."красивее". В этом танце уже практически никаких "бубнов", кроме разве что фичи, убирающей static из описания методов. Впечатление от курса - Wow !!! Все гениальное - просто (впрочем, как всегда у Мастера). Большое спасибо за пример универсального подхода к решению широкого класса задач, связанных с перебором/нахождением элементов и непосредственным их использованием в алгоритме без необходимости их "сохранения" в массиве. 
Сложности: самый простой урок по сравнению с предыдущими. Сложность курса в целом - отсутствие иллюстраций, отсылающих к теории. Мне помогли разобраться в происходящем ссылки на статьи https://docs.microsoft.com/en-us/dotnet/api/system.collections.generic.ienumerable-1?view=net-5.0 https://brainoteka.com/blogs/c-spravochnik/perechislyaemie-tipi-i-perechisliteli-ienumerable-i-ienumerato http://www.programmer-lib.ru/csharp_page.php?id=25 https://habr.com/ru/post/257667/ 
9 ФИНАЛЬНЫЙ УРОК без видео
82 чел. ★ 5 Done
  Поздравляю с окончанием курса!
Оставь, пожалуйста, отзыв о курсе.

Какой курс ты будешь проходить следующим?
Отчёт отправил: 11019. Trira Выполнено за 9 мин. [Показать отчёт]
Научился: Впечатление от курса - !!! Все гениальное - просто (впрочем, как всегда у Мастера). Большое спасибо за пример универсального подхода к решению широкого класса задач, связанных с перебором/нахождением элементов и непосредственным их использованием в алгоритме без необходимости их "сохранения" в массиве. Сложность курса в целом - отсутствие иллюстраций, отсылающих к теории. Мне помогли разобраться в происходящем ссылки на статьи docs.microsoft.com/en-us/dotnet/api/system.collections.generic.ienumerable-1?view=net-5.0 brainoteka.com/blogs/c-spravochnik/perechislyaemie-tipi-i-perechisliteli-ienumerable-i-ienumerato www.programmer-lib.ru/csharp_page.php?id=25 habr.com/ru/post/257667/ 
10 VIP. Оптимизация поиска простых чисел 01:19:28
1 тест
44 чел. ★ 5 ^
  Пишем функцию для поиска простых чисел и
поэтапно оптимизируем её в двух направлениях.
  Итого:   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#.

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


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


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