На этом курсе мы познакомимся с интерфейсами IEnumerable + IEnumerator.
На примере решения задачи разложения числа на простые множители
мы будем создавать итератор, который будет перебирать простые числа.
Содержание курса
+ создание класса по интерфейсу IEnumerable
+ создание класса по интерфейсу IEnumerator
+ подробное объяснение, зачем нужно два класса.
+ использование yield для удобной реализации итератора.
+ создание итератора через функцию, не создавая спец. класса.
# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 | Итератор. Разложение числа на простые множители. |
1 тест |
|||
На этом уроке мы создадим очевидный алгоритм, который будет раскладывать число на просты множители. Отчёт отправил: 17606. Виктор Выполнено за 9 час. 48 мин. [Показать отчёт] Научился: == Сложности: Не возникло |
|||||
2 | Итератор. Создание пустого итератора. |
1 тест |
|||
На этом уроке мы подберём ключ к циклу foreach. создадим класс, который позволит создать свой алгоритм для перебора значений в обычном цикле foreach. Нaпиши, что такое итератор, своими словами. Отчёт отправил: 17606. Виктор Выполнено за 1 час. 45 мин. [Показать отчёт] Научился: Как реализуются интерфейсы IEnumerable и IEnumerator Сложности: Не возникло |
|||||
3 | Итератор. Перебор чисел в итераторе. |
|
|||
На этом уроке мы добавим в созданный класс перебор чисел. Начнём с двойки и будем его всё время увеличивать "до бесконечности". В конце урока добавим ограничение, чтобы итератор останавливался. Отчёт отправил: 17606. Виктор Выполнено за 29 мин. [Показать отчёт] Научился: У меня все получилось) Сложности: Не возникло |
|||||
4 | Итератор. Перебор простых чисел. |
2 теста |
|||
На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл только простые числа, как и было задуманно изначально. Отчёт отправил: 17606. Виктор Выполнено за 1 час. 47 мин. [Показать отчёт] Научился: Возвращать в цикл только простые числа Сложности: Не возникло |
|||||
5 | Итератор. Зачем нужно два класса |
1 тест |
|||
На этом уроке мы разберёмся, зачем всё-таки нужно два класса один для создания итератора, второй для его использования. Для демонстрации напишем программу, которая выведет на экран таблицу умножения простых чисел. Отчёт отправил: 17606. Виктор Выполнено за 1 день 6 час. 1 мин. [Показать отчёт] Научился: Осознал необходимость реализации двух интерфейсов IEnumerator и IEnumerable в двух отдельных классах Сложности: Не возникло |
|||||
6 | Итератор. Волшебное слово yield. |
3 теста |
|||
На этом уроке мы узнаем, как упростить создание итератора. Для этого достаточно просто написать нужный нам цикл, внутри которого воспользоватся волшебным словом yield. Отчёт отправил: 17606. Виктор Выполнено за 2 час. 6 мин. [Показать отчёт] Научился: В очередной раз познакомился с оператором yield. На сей раз глубже, но до полного понимания еще полшага) Сложности: После предыдущего урока, в котором весь код перекроили полностью, пришлось по крупицам восстанавливать нынешний, чтобы продолжить курс. |
|||||
7 | Итератор. Список простых чисел. |
1 тест |
|||
На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка, который будет постепенно, по мере необходимости, пополняться новыми простыми числами. Отчёт отправил: 17606. Виктор Выполнено за 39 мин. [Показать отчёт] Научился: Все реализовал, число опробовал Сложности: Не возникло |
|||||
8 | Итератор. Один метод вместо классов. |
|
|||
На этом уроке мы увидим, что класс, оказывается, создавать не обязательно. Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов, и потом его можно использовать через обычный foreach в любом месте программы. Вся прелесть в том, что перебор элементов происходит по мере необходимости. Отчёт отправил: 17606. Виктор Выполнено за 35 мин. [Показать отчёт] Научился: Может и круто заменить класс на всего один метод, может и по производительности лучше, но мне в классе все было как-то понятнее) Кроме того, во многих курсах, мы избавляемся от static'a, а зачем до конца не понятно. Это как-то влияет на программу? На производительность? Сложности: Не возникло |
|||||
9 | ФИНАЛЬНЫЙ УРОК |
без видео |
|||
Поздравляю с окончанием курса! Оставь, пожалуйста, отзыв о курсе. Какой курс ты будешь проходить следующим? Отчёт отправил: 17606. Виктор Выполнено за 38 мин. [Показать отчёт] Научился: Курс хороший, мне понравился. Более глубоко разобрался в реализации интерфейсов IEnumerable и IEnumerator, а также в принципах работы оператора yield. Ценными оказались и комментарии Ивана Воронина в последнем уроке, спасибо ему за это. Следующей темой для прохождения возьму коллекции, по сути это продолжение изучения принципов работы двух вышеупомянутых интерфейсов. Курс "Коллекции" есть в разделе Java Сложности: Не возникло |
|||||
10 | VIP. Оптимизация поиска простых чисел |
1 тест |
|||
Пишем функцию для поиска простых чисел и поэтапно оптимизируем её в двух направлениях. Отчёт отправил: 17606. Виктор Выполнено за 9 час. 54 мин. [Показать отчёт] Научился: Урок получился супер! Мне все понравилось, думаю, скорее потому, что начинаю потихоньку созревать для такого кода. Тем более я сейчас осваиваю делегаты, а тут они во всей красе!) Кроме того, познакомился с великим множеством функций поиска простых чисел и с написанием системы для тестирования. Спасибо, за этот урок! Сложности: Не возникло |
|||||
Итого: 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 . |