На этом курсе мы познакомимся с интерфейсами IEnumerable + IEnumerator.
На примере решения задачи разложения числа на простые множители
мы будем создавать итератор, который будет перебирать простые числа.
Содержание курса
+ создание класса по интерфейсу IEnumerable
+ создание класса по интерфейсу IEnumerator
+ подробное объяснение, зачем нужно два класса.
+ использование yield для удобной реализации итератора.
+ создание итератора через функцию, не создавая спец. класса.
# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 | Итератор. Разложение числа на простые множители. |
1 тест |
|||
На этом уроке мы создадим очевидный алгоритм, который будет раскладывать число на просты множители. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 5 мин. [Показать отчёт] Научился: Писать алгоритм разложения на простые множители. Сложности: -- Комментарии: Чего-то переписала |
|||||
2 | Итератор. Создание пустого итератора. |
1 тест |
|||
На этом уроке мы подберём ключ к циклу foreach. создадим класс, который позволит создать свой алгоритм для перебора значений в обычном цикле foreach. Нaпиши, что такое итератор, своими словами. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 20 мин. [Показать отчёт] Научился: Создавать класс яперечислимый счетчик Сложности: Понять как так. Была функция, создающая новый объект, а мы взяли и вернули старый. Комментарии: Все-таки будет правильнее new Primes(...) c копированием полей ienumerable, если таковые имеются. |
|||||
3 | Итератор. Перебор чисел в итераторе. |
|
|||
На этом уроке мы добавим в созданный класс перебор чисел. Начнём с двойки и будем его всё время увеличивать "до бесконечности". В конце урока добавим ограничение, чтобы итератор останавливался. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 20 мин. [Показать отчёт] Научился: Устанавливать ограничение на цикл Сложности: Все еще пытаюсь понять почему не new Primes(...), ведь так нельзя вложенные циклы делать и счетчик надо обнулять при каждом запуске foreach Комментарии: Хотя, если взять за правило для каждого цикла новый экземпляр primes создавать... |
|||||
4 | Итератор. Перебор простых чисел. |
2 теста |
|||
На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл только простые числа, как и было задуманно изначально. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 20 мин. [Показать отчёт] Научился: Приводить объектный тип к объекту, который реализует некий интерфейс. Алгоритм поиска простых чисел. Сложности: Формат провайдера. Комментарии: Мах - 1000, но выводит 1007 |
|||||
5 | Итератор. Зачем нужно два класса |
1 тест |
|||
На этом уроке мы разберёмся, зачем всё-таки нужно два класса один для создания итератора, второй для его использования. Для демонстрации напишем программу, которая выведет на экран таблицу умножения простых чисел. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 30 мин. [Показать отчёт] Научился: Как избавляться от статика, хотя и таким незамысловатым способом - каждый раз передавая одно и то же значение... Сложности: Раз уж мы разбираем как делать нельзя... а почему мы не используем статик и не проверяем, что объект не занят? :-) Комментарии: Оставила один класс и убедилась, что все работает корректно. Хотя следовать шаблонам - это правильнее и понятнее другим разработчикам. |
|||||
6 | Итератор. Волшебное слово yield. |
3 теста |
|||
На этом уроке мы узнаем, как упростить создание итератора. Для этого достаточно просто написать нужный нам цикл, внутри которого воспользоватся волшебным словом yield. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 20 мин. [Показать отчёт] Научился: Возвращать объект IEnumerator Сложности: -- Комментарии: yield это такой синтаксический сахар, который сам создает экземпляр енумератора и этим упрощает жизнь кодеру. |
|||||
7 | Итератор. Список простых чисел. |
1 тест |
|||
На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка, который будет постепенно, по мере необходимости, пополняться новыми простыми числами. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 20 мин. [Показать отчёт] Научился: Добавили в наш класс (перечисляемые простые числа) лист, куда записали найденные значения. Сложности: С вложенным итератором уже мозг закипает как оно работает. Комментарии: Но при этом все выглядит очень просто и логично. |
|||||
8 | Итератор. Один метод вместо классов. |
|
|||
На этом уроке мы увидим, что класс, оказывается, создавать не обязательно. Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов, и потом его можно использовать через обычный foreach в любом месте программы. Вся прелесть в том, что перебор элементов происходит по мере необходимости. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 30 мин. [Показать отчёт] Научился: Сворачивать класс в функцию с параметром и исправлять свои ошибки. Сложности: -- Комментарии: В курсе рассматриваются такие темы как: поиск простых чисел, шаблон Итератор, применение интерфейсов IEnumerable, IEnumerator, IConvertable. После прохождения курса, вы перестанете бояться yield и поймете для чего это нужно и насколько это удобно. |
|||||
9 | ФИНАЛЬНЫЙ УРОК |
без видео |
|||
Поздравляю с окончанием курса! Оставь, пожалуйста, отзыв о курсе. Какой курс ты будешь проходить следующим? Отчёт отправил: 1232. Фомичева Наталья Выполнено за 5 мин. [Показать отчёт] Научился: Работать с итераторами как профи Сложности: Придумать еще один отзыв... побуду немного итератором. Комментарии: В курсе рассматриваются такие темы как: поиск простых чисел, шаблон Итератор, применение интерфейсов IEnumerable, IEnumerator, IConvertable. После прохождения курса, вы перестанете бояться yield и поймете для чего это нужно и насколько это удобно. |
|||||
10 | VIP. Оптимизация поиска простых чисел |
1 тест |
|||
Пишем функцию для поиска простых чисел и поэтапно оптимизируем её в двух направлениях. Отчёт отправил: 1232. Фомичева Наталья Выполнено за 1 час. 00 мин. [Показать отчёт] Научился: Повторила пройденное Сложности: Понять зачем "рефлекшен" использовать. Во фруктологике тоже думала перебрать все методы, но передумала, а не антипаттерн ли это. Комментарии: Хороший урок, чтоб еще раз пройтись по итераторам и сравнить скорость работы со статичными данными. Результат с учетом создания массива заново каждые мах*2^n раз. Ошибок почему-то нет... |
|||||
Итого: 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 . |