На этом курсе мы познакомимся с интерфейсами IEnumerable + IEnumerator.
На примере решения задачи разложения числа на простые множители
мы будем создавать итератор, который будет перебирать простые числа.
Содержание курса
+ создание класса по интерфейсу IEnumerable
+ создание класса по интерфейсу IEnumerator
+ подробное объяснение, зачем нужно два класса.
+ использование yield для удобной реализации итератора.
+ создание итератора через функцию, не создавая спец. класса.
# | Название видеоурока | Видео / Тесты | Решило | Рейтинг | Доступ |
---|---|---|---|---|---|
1 | Итератор. Разложение числа на простые множители. |
1 тест |
|||
На этом уроке мы создадим очевидный алгоритм, который будет раскладывать число на просты множители. Отчёт отправил: 6580. konstantin Выполнено за 29 мин. [Показать отчёт] Научился: повторил уже пройдено А вам знакома данная цифра? на первом скриншоте))). Сложности: ))) |
|||||
2 | Итератор. Создание пустого итератора. |
1 тест |
|||
На этом уроке мы подберём ключ к циклу foreach. создадим класс, который позволит создать свой алгоритм для перебора значений в обычном цикле foreach. Нaпиши, что такое итератор, своими словами. Отчёт отправил: 6580. konstantin Выполнено за 1 час. 13 мин. [Показать отчёт] Научился: я еще не до конца не понял что мы тут разбирали. может потом попозже пойму. Сложности: найти ошибку. компилятор постоянно на меня ругался по не известным мне причинам. но я потом разобрался и все исправил. |
|||||
3 | Итератор. Перебор чисел в итераторе. |
|
|||
На этом уроке мы добавим в созданный класс перебор чисел. Начнём с двойки и будем его всё время увеличивать "до бесконечности". В конце урока добавим ограничение, чтобы итератор останавливался. Отчёт отправил: 6580. konstantin Выполнено за 29 мин. [Показать отчёт] Научился: пользоваться IEnumerable. Сложности: пока что ничего . но надо бы закрепить знания. |
|||||
4 | Итератор. Перебор простых чисел. |
2 теста |
|||
На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл только простые числа, как и было задуманно изначально. Отчёт отправил: 6580. konstantin Выполнено за 23 мин. [Показать отчёт] Научился: ¯\_(ツ)_/¯ Сложности: ничего. |
|||||
5 | Итератор. Зачем нужно два класса |
1 тест |
|||
На этом уроке мы разберёмся, зачем всё-таки нужно два класса один для создания итератора, второй для его использования. Для демонстрации напишем программу, которая выведет на экран таблицу умножения простых чисел. Отчёт отправил: 6580. konstantin Выполнено за 51 мин. [Показать отчёт] Научился: все больше и больше начинаю понимать, что и зачем. ( ゚ヮ゚) но не могу объяснить что я понял ¯\_(ツ)_/¯ Сложности: все ясно и понятно |
|||||
6 | Итератор. Волшебное слово yield. |
3 теста |
|||
На этом уроке мы узнаем, как упростить создание итератора. Для этого достаточно просто написать нужный нам цикл, внутри которого воспользоватся волшебным словом yield. Отчёт отправил: 6580. konstantin Выполнено за 1 час. 18 мин. [Показать отчёт] Научился: оператору yield? который передается значение переменной в цикле foreach не прекращая перебор внутри IEnumerable. ну как то так. Сложности: Найти ошибку в коде. программа выдавала все цифры подряд. Выяснилось что в какой то момент переменная prime в методе IsPraim() сбрасывалась на единицу и в итоге у меня выходило что условие не выполнялось внутри цикла. Решение: Добавил объявление переменной методу IsPraim(long g). |
|||||
7 | Итератор. Список простых чисел. |
1 тест |
|||
На этом уроке мы перепишем алгоритм перебора простых чисел с использованием списка, который будет постепенно, по мере необходимости, пополняться новыми простыми числами. Отчёт отправил: 6580. konstantin Выполнено за 27 мин. [Показать отчёт] Научился: Использовать list . Представляет строго типизированный список объектов, доступных по индексу. Поддерживает методы для поиска по списку, выполнения сортировки и других операций со списками. https://msdn.microsoft.com/ru-ru/library/6sh2ey19(v=vs.110).aspx Сложности: null |
|||||
8 | Итератор. Один метод вместо классов. |
|
|||
На этом уроке мы увидим, что класс, оказывается, создавать не обязательно. Магия слова yield сделает всё за тебя, можно просто один раз организовать перебор нужных элементов, и потом его можно использовать через обычный foreach в любом месте программы. Вся прелесть в том, что перебор элементов происходит по мере необходимости. Отчёт отправил: 6580. konstantin Выполнено за 23 мин. [Показать отчёт] Научился: Это способ перебора горазда лучше по скорости. На скриншотах два примера перебора простых чисел. с лева мой старый метод, а с права данный метод. Результат на лицо. Сложности: null |
|||||
9 | ФИНАЛЬНЫЙ УРОК |
без видео |
|||
Поздравляю с окончанием курса! Оставь, пожалуйста, отзыв о курсе. Какой курс ты будешь проходить следующим? Отчёт отправил: 6580. konstantin Выполнено за 9 мин. [Показать отчёт] Научился: Курс очень хороший. Если хотите ускорить перебор в своей программе пройдите данный курс. По началу вам может показаться что вы ничего не понимаете. Но выполняя каждый урок до тех пор пока у вас не перестанет ругаться компилятор, и будет рабочая программа. Вы хотя бы про анализируете все шаги программы или посмотрите их хотя бы на 10 циклов вы начнете понимать о чем идет речь. и уже поймете где нужно применять данную практику. на скриншоте: слева старый метод. с права новый метод перебора простых числе. пока новый перебрал все числа старый усердно их перебирает и начинает притормаживать. Сложности: null |
|||||
10 | VIP. Оптимизация поиска простых чисел |
1 тест |
|||
Пишем функцию для поиска простых чисел и поэтапно оптимизируем её в двух направлениях. Отчёт отправил: 6580. konstantin Выполнено за 6 час. 10 мин. [Показать отчёт] Научился: делать проверку метода сравнивая результат с эталоном. немного понял что такое делегаты. ограничивать время работы куска кода. познакомился с методами поиска простых числе и их эффективностью. Сложности: после проверки казалось что почти все функции давали ошибки. долго и упорно искал и исправлял)))) но в итоге 0 errors |
|||||
Итого: 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 . |