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