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