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