На этом курсе мы познакомимся с интерфейсами IEnumerable + IEnumerator.
На примере решения задачи разложения числа на простые множители
мы будем создавать итератор, который будет перебирать простые числа.
Содержание курса
+ создание класса по интерфейсу IEnumerable
+ создание класса по интерфейсу IEnumerator
+ подробное объяснение, зачем нужно два класса.
+ использование yield для удобной реализации итератора.
+ создание итератора через функцию, не создавая спец. класса.
# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 | Итератор. Разложение числа на простые множители. |
1 тест |
|||
На этом уроке мы создадим очевидный алгоритм, который будет раскладывать число на просты множители. Отчёт отправил: 13846. Zebos Выполнено за 20 мин. [Показать отчёт] Научился: Вспомнил про разложение числа на простые множители и признаки делимости Сложности: сложностей нет Комментарии: задачка вдохновила пробежаться по определениям арифметики. |
|||||
2 | Итератор. Создание пустого итератора. |
1 тест |
|||
На этом уроке мы подберём ключ к циклу foreach. создадим класс, который позволит создать свой алгоритм для перебора значений в обычном цикле foreach. Нaпиши, что такое итератор, своими словами. Отчёт отправил: 13846. Zebos Выполнено за 40 мин. [Показать отчёт] Научился: Создавать классы, реализующие интерфейсы IEnumerable, IEnumerator Сложности: нет сложностей, все логично Комментарии: Итератор - объект, который обеспечивает доступ к элементам и перемещение по последовательности данных. |
|||||
3 | Итератор. Перебор чисел в итераторе. |
|
|||
На этом уроке мы добавим в созданный класс перебор чисел. Начнём с двойки и будем его всё время увеличивать "до бесконечности". В конце урока добавим ограничение, чтобы итератор останавливался. Отчёт отправил: 13846. Zebos Выполнено за 30 мин. [Показать отчёт] Научился: Реализовывать интерфейс IEnumerator Сложности: сложностей не было Комментарии: Магия итераторов рассеивается) |
|||||
4 | Итератор. Перебор простых чисел. |
2 теста |
|||
На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл только простые числа, как и было задуманно изначально. Отчёт отправил: 13846. Zebos Выполнено за 35 мин. [Показать отчёт] Научился: Лучшее понимание работы интерфейсов Сложности: По не возникает сложностей Комментарии: Интерес нарастает. |
|||||
5 | Итератор. Зачем нужно два класса |
1 тест |
|||
На этом уроке мы разберёмся, зачем всё-таки нужно два класса один для создания итератора, второй для его использования. Для демонстрации напишем программу, которая выведет на экран таблицу умножения простых чисел. Отчёт отправил: 13846. Zebos Выполнено за 35 мин. [Показать отчёт] Научился: Научился более глубокому пониманию механики IEnumerable и IEnumerator Сложности: нет сложностей Комментарии: Хорошо понятно, почему используется для организации обхода 2 класса. |
|||||
6 | Итератор. Волшебное слово yield. |
3 теста |
|||
На этом уроке мы узнаем, как упростить создание итератора. Для этого достаточно просто написать нужный нам цикл, внутри которого воспользоватся волшебным словом yield. Отчёт отправил: 13846. Zebos Выполнено за 20 мин. [Показать отчёт] Научился: Использованию yield. Сложности: нет сложностей Комментарии: Yield позволяет избавится от реализации дополнительного класса , при использовании цикла foreach. И в определенных ситуациях оптимизировать вычисления при большом переборе значений. |
|||||
7 | Итератор. Список простых чисел. |
1 тест |
|||
На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка, который будет постепенно, по мере необходимости, пополняться новыми простыми числами. Отчёт отправил: 13846. Zebos Выполнено за 20 мин. [Показать отчёт] Научился: Узнал интересный алгоритм поиска простых чисел Сложности: не было сложностей Комментарии: Лучше стал понимать механизм работы Ienumerator и Yield |
|||||
8 | Итератор. Один метод вместо классов. |
|
|||
На этом уроке мы увидим, что класс, оказывается, создавать не обязательно. Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов, и потом его можно использовать через обычный foreach в любом месте программы. Вся прелесть в том, что перебор элементов происходит по мере необходимости. Отчёт отправил: 13846. Zebos Выполнено за 10 мин. [Показать отчёт] Научился: Научился интересной реализации работы с перечислениями без создания классов. Сложности: нет сложностей Комментарии: Очень полезный курс, помог лучше понять работу с перечислениями и итераторами. Так же более понятна теперь работа корутинов в движке Unity. |
|||||
9 | ФИНАЛЬНЫЙ УРОК |
без видео |
|||
Поздравляю с окончанием курса! Оставь, пожалуйста, отзыв о курсе. Какой курс ты будешь проходить следующим? Отчёт отправил: 13846. Zebos Выполнено за 5 мин. [Показать отчёт] Научился: Научился разным реализациям работы с перечислениями, лучшему пониманию механики итераторов и работы с коллекциями. Все это помогло на практике с движком Unity Сложности: сложностей не было Комментарии: Очень понравилось , что задача решена различными методами, даже в книгах редко встречается такой всесторонний подход. Есть над чем поразмыслить и попрактиковаться. Возможно следующий курс ООП, игры или упорядочивание основ с#. |
|||||
10 | VIP. Оптимизация поиска простых чисел |
1 тест |
|||
Пишем функцию для поиска простых чисел и поэтапно оптимизируем её в двух направлениях. |
|||||
Итого: 10 видеоуроков |
2 час. 42 мин. 10 тестов |
44 чел. | |||
Финалисты: Иван Воронин, Елена, Артём, Новопашин Владимир, Алексей В., Фомичева Наталья, 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 . |