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