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