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

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

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

Итератор

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

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

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


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

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

Нaпиши, что такое итератор, своими словами.
Отчёт отправил: 4814. Дмитрий Выполнено за 6 час. 7 мин. [Показать отчёт]
Научился: Создали 2 класса с интерфейсами IEnumerable и IEnumerator и объединили их в один. Итератор - это интерфейс, предоставляющий доступ к элементам. 
Сложности: Тяжко это воспринимается. :-( 
3 Итератор. Перебор чисел в итераторе. 00:09:04
113 чел. ★ 4.9 Done
  На этом уроке мы добавим в созданный класс перебор чисел.
Начнём с двойки и будем его всё время увеличивать "до бесконечности".
В конце урока добавим ограничение, чтобы итератор останавливался.
Отчёт отправил: 4814. Дмитрий Выполнено за 1 час. 21 мин. [Показать отчёт]
Научился: Добавили ограничение для счетчика. 
Сложности: Понятно, но тема очень сложная для восприятия. 
4 Итератор. Перебор простых чисел. 00:10:28
1 тест
111 чел. ★ 4.9 Done
  На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл
только простые числа, как и было задуманно изначально.
Отчёт отправил: 4814. Дмитрий Выполнено за 21 час. 10 мин. [Показать отчёт]
Научился: Написали метод isPrime проверки на простое число, доработали метод MoveNext. 
Сложности: По отдельности все понятно, но в целом тему сложно воспринять. :-( 
5 Итератор. Зачем нужно два класса 00:16:21
1 тест
99 чел. ★ 4.9 Done
  На этом уроке мы разберёмся, зачем всё-таки нужно два класса
один для создания итератора, второй для его использования.
Для демонстрации напишем программу, которая выведет
на экран таблицу умножения простых чисел.
Отчёт отправил: 4814. Дмитрий Выполнено за 7 час. 42 мин. [Показать отчёт]
Научился: Разделили процесс создания итератора на 2 класса, создали 2 цикла и таблицу умножения для простых чисел. 
Сложности: Сложная для восприятия тема. 
6 Итератор. Волшебное слово yield. 00:11:03
2 теста
97 чел. ★ 4.9 Done
  На этом уроке мы узнаем, как упростить создание итератора.
Для этого достаточно просто написать нужный нам цикл,
внутри которого воспользоватся волшебным словом yield.

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

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

Отчёт отправил: 4814. Дмитрий Выполнено за 1 час. 18 мин. [Показать отчёт]
Научился: Упростили код, избавились от лишнего класса, а также статичности метода. 
Сложности: Тема очень интересная, полезная, но визуально для восприятия довольно сложная. Реализация итератора позволяет через цикл foreach обращаться ко всем элементам совокупности объектов по очереди, причем динамически. 
9 ФИНАЛЬНЫЙ УРОК без видео
77 чел. ★ 4.9 Done
  Поздравляю с окончанием курса!
Оставь, пожалуйста, отзыв о курсе.

Какой курс ты будешь проходить следующим?
Отчёт отправил: 4814. Дмитрий Выполнено за 1 день 2 мин. [Показать отчёт]
Научился: Итератор - это метод, возвращающий по очереди члены совокупности объектов от ее начала и до конца. Реализовав итератор, можно обращаться к объектам определяемого класса в цикле foreach.  
Сложности: Сложности: Тема очень интересная, полезная, но визуально для восприятия довольно сложная. Реализация итератора позволяет через цикл foreach обращаться ко всем элементам совокупности объектов по очереди, причем динамически.  
10 VIP. Оптимизация поиска простых чисел 01:19:28
1 тест
41 чел. ★ 5 Done
  Пишем функцию для поиска простых чисел и
поэтапно оптимизируем её в двух направлениях.
Отчёт отправил: 4814. Дмитрий Выполнено за 8 дней 23 час. 55 мин. [Показать отчёт]
Научился: Основам оптимизации. 
Сложности: Все отлично. Но 10-минутные уроки проще делать. 
  Итого:   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#.

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


Научился: Курс очень хороший. Если хотите ускорить перебор в своей программе пройдите данный курс. По началу вам может показаться что вы ничего не понимаете. Но выполняя каждый урок до тех пор пока у вас не перестанет ругаться компилятор, и будет рабочая программа. Вы хотя бы про анализируете все шаги программы или посмотрите их хотя бы на 10 циклов вы начнете понимать о чем идет речь. и уже поймете где нужно применять данную практику. на скриншоте: слева старый метод. с права новый метод перебора простых числе. пока новый перебрал все числа старый усердно их перебирает и начинает притормаживать.



Научился: Подвел для себя итоги курса
Трудности: Понимание новых концепций
Прекрасный курс. Детально рассмотрены современные типы IENumerable, IENumerator Уроки проведены в непринужденной манере с упором на практическое экспериментирование с различными аспектами темы. Можно было бы немного "утяжелить" задания для самостоятельного решения. Дальше планирую изучить - "Бурные потоки".