На этом курсе мы познакомимся с интерфейсами IEnumerable + IEnumerator.
На примере решения задачи разложения числа на простые множители
мы будем создавать итератор, который будет перебирать простые числа.
Содержание курса
+ создание класса по интерфейсу IEnumerable
+ создание класса по интерфейсу IEnumerator
+ подробное объяснение, зачем нужно два класса.
+ использование yield для удобной реализации итератора.
+ создание итератора через функцию, не создавая спец. класса.
# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 | Итератор. Разложение числа на простые множители. |
1 тест |
|||
На этом уроке мы создадим очевидный алгоритм, который будет раскладывать число на просты множители. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 12 мин. [Показать отчёт] Научился: Научился раскладывать число на простые множители. Сложности: Сложность алгоритма O^2 Комментарии: Хорошее начало курса и полезный урок. |
|||||
2 | Итератор. Создание пустого итератора. |
1 тест |
|||
На этом уроке мы подберём ключ к циклу foreach. создадим класс, который позволит создать свой алгоритм для перебора значений в обычном цикле foreach. Нaпиши, что такое итератор, своими словами. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 11 мин. [Показать отчёт] Научился: Научился создавать свой иттератор. Сложности: Ничего. Комментарии: Иттератор - это генератор объектов - не важно чего - чисел, букв, можно последовательно даты месяца или рабочие дни генерировать - можно генератор уточек делать - короче генератор любых объектов. В нашем случае мы пытаемся генерировать простые числа. |
|||||
3 | Итератор. Перебор чисел в итераторе. |
|
|||
На этом уроке мы добавим в созданный класс перебор чисел. Начнём с двойки и будем его всё время увеличивать "до бесконечности". В конце урока добавим ограничение, чтобы итератор останавливался. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 10 мин. [Показать отчёт] Научился: Научился доводить до ума созданный иттератор. Сложности: Ничего. Комментарии: Ура! Заработало! |
|||||
4 | Итератор. Перебор простых чисел. |
2 теста |
|||
На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл только простые числа, как и было задуманно изначально. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 10 мин. [Показать отчёт] Научился: Научил иттератор работать с простыми числами. Сложности: Ничего. Комментарии: --- |
|||||
5 | Итератор. Зачем нужно два класса |
1 тест |
|||
На этом уроке мы разберёмся, зачем всё-таки нужно два класса один для создания итератора, второй для его использования. Для демонстрации напишем программу, которая выведет на экран таблицу умножения простых чисел. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 50 мин. [Показать отчёт] Научился: Научился выводить таблицу умножения. Сложности: Ничего. Комментарии: --- |
|||||
6 | Итератор. Волшебное слово yield. |
3 теста |
|||
На этом уроке мы узнаем, как упростить создание итератора. Для этого достаточно просто написать нужный нам цикл, внутри которого воспользоватся волшебным словом yield. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 11 мин. [Показать отчёт] Научился: Узнал о новом слове yield. Сложности: Что значит слово yield? Комментарии: Код значительно сократился - супер! |
|||||
7 | Итератор. Список простых чисел. |
1 тест |
|||
На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка, который будет постепенно, по мере необходимости, пополняться новыми простыми числами. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 15 мин. [Показать отчёт] Научился: Научился перебирать простые числа болеее изящным способом. Сложности: Ничего. Комментарии: Кстати по умолчанию если пишем return 2 возвращается int32, чтобы вернулся long надо писать return 2L;, чтобы вернулся Double - return 2.0;, чтобы вернулся Decimal - return 2M; |
|||||
8 | Итератор. Один метод вместо классов. |
|
|||
На этом уроке мы увидим, что класс, оказывается, создавать не обязательно. Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов, и потом его можно использовать через обычный foreach в любом месте программы. Вся прелесть в том, что перебор элементов происходит по мере необходимости. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 15 мин. [Показать отчёт] Научился: Научился класс итератора переводить в метод. Сложности: Самое, сложное хотелось самостоятельно перевести в метод и все никак не получалось - потом запустил видео и посмотрел в чем была ошибка. Комментарии: Хороший курс - позволяет понять , что под капотом находится. Логичным продолжением этого курса я бы хотел видеть курс по LINQ - ведь именно там активно используются интерфейся IEnumerator и IEnumerable. |
|||||
9 | ФИНАЛЬНЫЙ УРОК |
без видео |
|||
Поздравляю с окончанием курса! Оставь, пожалуйста, отзыв о курсе. Какой курс ты будешь проходить следующим? Отчёт отправил: 7119. Новопашин Владимир Выполнено за 20 мин. [Показать отчёт] Научился: Научился писать видеоотзыв. Сложности: Не запутаться в словах - это самое сложное. Комментарии: Следующим курсом буду проходить либо базовый аспект, либо базу оценок. Может еще какой-нибудь. Видеообзор: https://youtu.be/wkdQXE4MRFM |
|||||
10 | VIP. Оптимизация поиска простых чисел |
1 тест |
|||
Пишем функцию для поиска простых чисел и поэтапно оптимизируем её в двух направлениях. Отчёт отправил: 7119. Новопашин Владимир Выполнено за 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 . |