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

Формула программиста
основатель — Волосатов Евгений Витольдович
C# Олимпиада из Простоквашино
Вебинар «Комбинаторные алгоритмы» начнётся через 11 час. 27 мин.

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

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




Оцени работу

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

  • Отчёт оценивали:
    9567Максим+1   2146Иван+1   689Igorenzia+1   6925Артём+1   4992Николай+1   9237Mais+1   3506Алексей|BrisK|Кривицкий+1   1Евгений Волосатов+1   8380zhikharevav+1   9263Андрей Н.+1   4467Alcatraz+1   4395Денис+1   1537Сергей+1   6644valerys Nikola+1   Посетитель+1   9876Hozy+1   6452Кирилл Шмойлов+1   6203Николай (nick27m)+1   7652Петя+1   8886Михаил Ермишин+1  

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




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

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

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

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