Курсы по программированию

Формула программиста
основатель — Волосатов Евгений Витольдович

Итератор / Итератор. Перебор простых чисел.

  • На этом уроке мы сдеаем так, чтобы наш класс возвращал в цикл
    только простые числа, как и было задуманно изначально.
  • Дата отправки отчёта: 8 апреля 2016 г.
  • Задание выполнено: за 30 мин.
  • Чему научился: Продолжил знакомство с итераторами
  • Что было сложным: Все понятно
  • Комментарии: Нет
  • Оценка видео-уроку:
Отчёт от 9323 за Итератор / Итератор. Перебор простых чисел.




Оцени работу

 
Сохранить страницу:

  • Отчёт оценивали:
    9237Mais+1   Посетитель+1   Посетитель+1   9544Даниил Степаненко+1   6452Кирилл Шмойлов+1   4992Николай+1   7645Александр Львович+1   689Igorenzia+1   4467Alcatraz+1   2721mikemet+1   1Евгений Волосатов+1   6925Артём+1   8835Булат+1   459Сергей Сергеевич+1   3506Алексей|BrisK|Кривицкий+1   9332Dima+1   36Данил+1   7652Петя+1   8380zhikharevav+1   6391Владимир+1  

Начинаем практику по языку C#




Чтобы стать хорошим программистом — нужно писать программы. На нашем сайте очень много практических упражнений.

После заполнения формы ты будешь подписан на рассылку «C# Вебинары и Видеоуроки», у тебя появится доступ к видеоурокам и консольным задачам.

Несколько раз в неделю тебе будут приходить письма — приглашения на вебинары, информация об акциях и скидках, полезная информация по C#.

Ты в любой момент сможешь отписаться от рассылки.
Научился: Глубже разобрался с задачей поиска простых чисел.
Трудности: Не мог понять почему в методе IsPrime мы крутим цикл до prime/2, а не до prime-1. Но потом прочитал, что можно вообще до Math.Sqrt(prime). Также, не смог оценить мат. сложность реализации (в смысле О большого).
Стало интересно оценить скорость работы алгоритма. Использовал StopWatch. Выяснилось, что дополнительный вызов метода IsPrime значительно замедляет поиск. А переустановка SetMax(number) на каждом шаге основного цикла - здорово ускоряет работу (порядка тысячи раз). Также логика подсказывает, что при вызове IsPrime() после каждого инкремента выполняется много лишней работы, так как перебираются каждый раз практически одни и те же числа. Не лучше ли вести какой-то список уже найденных простых чисел?
Научился: Я узнал об итераторах. узнал о классе IENumerable. Получил много полезных знаний
Урок понравился. За короткое время узнал много нового. Особенно понравился вариант программы с использованием оператора yield :~) Спасибо за урок! Он замечателен!