На этом курсе мы познакомимся с интерфейсами IEnumerable + IEnumerator.
На примере решения задачи разложения числа на простые множители
мы будем создавать итератор, который будет перебирать простые числа.
Содержание курса
+ создание класса по интерфейсу IEnumerable
+ создание класса по интерфейсу IEnumerator
+ подробное объяснение, зачем нужно два класса.
+ использование yield для удобной реализации итератора.
+ создание итератора через функцию, не создавая спец. класса.
# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 | Итератор. Разложение числа на простые множители. |
1 тест |
|||
На этом уроке мы создадим очевидный алгоритм, который будет раскладывать число на просты множители. Отчёт отправил: 4004. Елена Выполнено за 15 мин. [Показать отчёт] Научился: Повторение раскладывания числа на простые множители Сложности: ничего Комментарии: Давно хотела пройти этот курс. Наконец, решилась :) На очереди - "Коллекция графов" |
|||||
2 | Итератор. Создание пустого итератора. |
1 тест |
|||
На этом уроке мы подберём ключ к циклу foreach. создадим класс, который позволит создать свой алгоритм для перебора значений в обычном цикле foreach. Нaпиши, что такое итератор, своими словами. Отчёт отправил: 4004. Елена Выполнено за 20 мин. [Показать отчёт] Научился: Работать с IEnumerator и IEnumerable Сложности: Пока до конца не понимаю назначения этих классов. Комментарии: Реализовывать интерфейс классов всё-таки проще так, как показывал Андрей в своей олимпиаде "Четыре в ряд". |
|||||
3 | Итератор. Перебор чисел в итераторе. |
|
|||
На этом уроке мы добавим в созданный класс перебор чисел. Начнём с двойки и будем его всё время увеличивать "до бесконечности". В конце урока добавим ограничение, чтобы итератор останавливался. Отчёт отправил: 4004. Елена Выполнено за 15 мин. [Показать отчёт] Научился: Добавлять ограничение для счетчика и числа в IEnumerator Сложности: вроде бы ничего Комментарии: Интересный урок |
|||||
4 | Итератор. Перебор простых чисел. |
2 теста |
|||
На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл только простые числа, как и было задуманно изначально. Отчёт отправил: 4004. Елена Выполнено за 20 мин. [Показать отчёт] Научился: Искать простые числа Сложности: Пока я не поняла, в чем выигрыш при использовании Enumerator, Enumerable Комментарии: К реализации IEnumerator.MoveNext() и т.п. уже приходила сама в одном из предыдущих уроков. Но отказалась от нее, поскольку в уроке требовалось сделать через public. |
|||||
5 | Итератор. Зачем нужно два класса |
1 тест |
|||
На этом уроке мы разберёмся, зачем всё-таки нужно два класса один для создания итератора, второй для его использования. Для демонстрации напишем программу, которая выведет на экран таблицу умножения простых чисел. Отчёт отправил: 4004. Елена Выполнено за 25 мин. [Показать отчёт] Научился: Выделять два класса Сложности: Долго не могла найти ошибку "улетающих чисел в консоли". Оказалось, что не передала параметр primesMax в класс PrimesIterator. Комментарии: Я всё-таки предпочитаю конструкторы со значениями по умолчанию. Вместо того, чтобы делать два одинаковых конструктора: public Primes(long max = -1) { primeMax = max; } |
|||||
6 | Итератор. Волшебное слово yield. |
3 теста |
|||
На этом уроке мы узнаем, как упростить создание итератора. Для этого достаточно просто написать нужный нам цикл, внутри которого воспользоватся волшебным словом yield. Отчёт отправил: 4004. Елена Выполнено за 15 мин. [Показать отчёт] Научился: Использовать yield return Сложности: Не поняла, что такое yield break и почему именно его необходимо использовать Комментарии: Немного запутанный урок получился. Видимо, потому что предыдущий урок был добавлен после курса, и код мой отличается от того, с которым начинается работа в начале урока. Некоторые вещи пришлось "додумывать" самой. |
|||||
7 | Итератор. Список простых чисел. |
1 тест |
|||
На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка, который будет постепенно, по мере необходимости, пополняться новыми простыми числами. Отчёт отправил: 4004. Елена Выполнено за 30 мин. [Показать отчёт] Научился: Использовать список для перебора простых чисел Сложности: Не отвлекаться :) Так я и не поняла, зачем мы наследовали класс IEnumerable. Со списком всё понятно. Комментарии: В п.2 по этому уроку - опечатка - "алгорит" |
|||||
8 | Итератор. Один метод вместо классов. |
|
|||
На этом уроке мы увидим, что класс, оказывается, создавать не обязательно. Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов, и потом его можно использовать через обычный foreach в любом месте программы. Вся прелесть в том, что перебор элементов происходит по мере необходимости. Отчёт отправил: 4004. Елена Выполнено за 15 мин. [Показать отчёт] Научился: Использовать функцию перебора простых чисел без класса. Наконец-то поняла, для чего нужен IEnumerable Сложности: Долго не могла найти ошибку - IEnumerator вместо IEnumerable. Потом разобралась. Комментарии: Дошло наконец-то, к концу курса, зачем IEnumerable нужен - чтобы хранить все перечисленные в списке простые числа, из которых уже выбирается параметр цикла foreach в Main(). |
|||||
9 | ФИНАЛЬНЫЙ УРОК |
без видео |
|||
Поздравляю с окончанием курса! Оставь, пожалуйста, отзыв о курсе. Какой курс ты будешь проходить следующим? Отчёт отправил: 4004. Елена Выполнено за 5 мин. [Показать отчёт] Научился: Составлять отзыв Сложности: Наверное, пройти курс за 2 дня Комментарии: Хотя... это не сложно, учитывая, что курс интересный, что я давно собиралась его пройти и что курс оправдал мои ожидания. Следующий курс - "Коллекция графа". Правда, он побольше - за 2 дня пройти уже не получится. |
|||||
10 | VIP. Оптимизация поиска простых чисел |
1 тест |
|||
Пишем функцию для поиска простых чисел и поэтапно оптимизируем её в двух направлениях. Отчёт отправил: 4004. Елена Выполнено за 2 час. 00 мин. [Показать отчёт] Научился: Генерировать простые числа Сложности: Найти время, чтобы выполнить такой большой урок. Комментарии: Вчера не успела закончить, пришлось доделывать сегодня. Отвыкла я уже от длинных уроков :) |
|||||
Итого: 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 . |