На этом курсе мы познакомимся с интерфейсами IEnumerable + IEnumerator.
На примере решения задачи разложения числа на простые множители
мы будем создавать итератор, который будет перебирать простые числа.
Содержание курса
+ создание класса по интерфейсу IEnumerable
+ создание класса по интерфейсу IEnumerator
+ подробное объяснение, зачем нужно два класса.
+ использование yield для удобной реализации итератора.
+ создание итератора через функцию, не создавая спец. класса.
# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 | Итератор. Разложение числа на простые множители. |
1 тест |
|||
На этом уроке мы создадим очевидный алгоритм, который будет раскладывать число на просты множители. Отчёт отправил: 15445. Kitsuneco Выполнено за 5 час. 59 мин. [Показать отчёт] Научился: Алгоритму нахождения простых чисел Сложности: Всё было просто |
|||||
2 | Итератор. Создание пустого итератора. |
1 тест |
|||
На этом уроке мы подберём ключ к циклу foreach. создадим класс, который позволит создать свой алгоритм для перебора значений в обычном цикле foreach. Нaпиши, что такое итератор, своими словами. Отчёт отправил: 15445. Kitsuneco Выполнено за 13 мин. [Показать отчёт] Научился: Реализовывать интерфейсы, в частности, именно интерфейсы INumerable и INumerator Сложности: Понять, как работает foreach и зачем нам нужны эти интерфейсы |
|||||
3 | Итератор. Перебор чисел в итераторе. |
|
|||
На этом уроке мы добавим в созданный класс перебор чисел. Начнём с двойки и будем его всё время увеличивать "до бесконечности". В конце урока добавим ограничение, чтобы итератор останавливался. Отчёт отправил: 15445. Kitsuneco Выполнено за 1 час. 39 мин. [Показать отчёт] Научился: Урок короткий и промежуточный, но чуть более детально стала ясна работа итератора, который мы реализуем Сложности: На данном уроке всё было достаточно понятно и просто |
|||||
4 | Итератор. Перебор простых чисел. |
2 теста |
|||
На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл только простые числа, как и было задуманно изначально. Отчёт отправил: 15445. Kitsuneco Выполнено за 23 час. 5 мин. [Показать отчёт] Научился: Ограничивать доступ к функциям по реализуемым интерфейсам Сложности: Понять момент в самом конце, связанный с типом string |
|||||
5 | Итератор. Зачем нужно два класса |
1 тест |
|||
На этом уроке мы разберёмся, зачем всё-таки нужно два класса один для создания итератора, второй для его использования. Для демонстрации напишем программу, которая выведет на экран таблицу умножения простых чисел. Отчёт отправил: 15445. Kitsuneco Выполнено за 29 мин. [Показать отчёт] Научился: Понял, зачем нужны именно два класса и одним ограничиться не получиться. Сложности: Понять, как работают вложенные foreach. |
|||||
6 | Итератор. Волшебное слово yield. |
3 теста |
|||
На этом уроке мы узнаем, как упростить создание итератора. Для этого достаточно просто написать нужный нам цикл, внутри которого воспользоватся волшебным словом yield. Отчёт отправил: 15445. Kitsuneco Выполнено за 11 час. 12 мин. [Показать отчёт] Научился: Работе с ключевым словом yield Используя yield return мы делаем так, чтобы метод вернул последовательность IEnumerable, элементами которой являются результаты выражений каждого из yield return Сложности: Понять принцип работы yield |
|||||
7 | Итератор. Список простых чисел. |
1 тест |
|||
На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка, который будет постепенно, по мере необходимости, пополняться новыми простыми числами. Отчёт отправил: 15445. Kitsuneco Выполнено за 47 мин. [Показать отчёт] Научился: Алгоритму генерации простых чисел посредством yield Сложности: Всё было понятно |
|||||
8 | Итератор. Один метод вместо классов. |
|
|||
На этом уроке мы увидим, что класс, оказывается, создавать не обязательно. Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов, и потом его можно использовать через обычный foreach в любом месте программы. Вся прелесть в том, что перебор элементов происходит по мере необходимости. Отчёт отправил: 15445. Kitsuneco Выполнено за 16 мин. [Показать отчёт] Научился: Реализовать всё сделанное ранее всего лишь через один метод, не используя классы. Сложности: Перестройка кода (логика избавления от классов) |
|||||
9 | ФИНАЛЬНЫЙ УРОК |
без видео |
|||
Поздравляю с окончанием курса! Оставь, пожалуйста, отзыв о курсе. Какой курс ты будешь проходить следующим? Отчёт отправил: 15445. Kitsuneco Выполнено за 3 мин. [Показать отчёт] Научился: Курс хороший. Познакомил меня с таким явлением как "итератор" и подробно расскрыл что же находится под катопотом у foreach. Было бы интересно, если бы подобные детальные разборы существовали и для различных остальных конструкций в языке. Скорее всего, дальше приступлю к курсу "Демо софт" Сложности: Понять как функционируют интерфейсы и yield |
|||||
10 | VIP. Оптимизация поиска простых чисел |
1 тест |
|||
Пишем функцию для поиска простых чисел и поэтапно оптимизируем её в двух направлениях. Отчёт отправил: 15445. Kitsuneco Выполнено за 1 час. 37 мин. [Показать отчёт] Научился: Эффективным алгоритмам поиска простых чисел Сложности: Алгоритмы в конце; пришлось пересмотреть дважды на некоторых моментах, чтобы вникнуть |
|||||
Итого: 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 . |