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