Форум программистов, компьютерный форум, киберфорум
Алгоритмы
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98

Список простых чисел

20.10.2017, 20:17. Показов 1215. Ответов 14
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Чтобы не плодить темы, решил спросить тут. Вот кусок программы, он на JS, но это не важно. Он должен пропускать простые числа(те, которые делятся без остатка только на 1 и на себя), и записывать в счетчик составные. Сама программа работает, но я всю голову сломал почему она работает! Ведь, как минимум часть i <= Math.sqrt(n) никогда не будет true, так как i всегда будет больше n на единицу... я в программировании новичек, но вроде бы с циклом for разобрался. А тут что-то непонятное. Во вторых, зачем извлекать корень квадратный...
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
var n = 1
 
search: while (true)
{
  n += 1
 
  for (var i = 2; i <= Math.sqrt(n); i += 1)
  {
    if (n % i == 0) continue search
  }
 
  postMessage(n)
}
Вот описание работы алгоритма автором: В этом файле переменной n присваивается значение 1. Затем запускается бесконечный цикл с увеличением значения n на единицу и проверкой значения «в лоб» на принадлежность к простым числам. При этом тестируются все значения от 1 до корня квадратного из n для проверки, делится ли n на них без остатка. Если сомножитель будет найден, то команда continue тут же останавливает лобовую атаку, поскольку число не является простым, и начинает обработку снова в отношении следующего более высокого значения n.
Но если все возможные сомножители будут протестированы и не будет найден результат с нулевым остатком, то n должно быть простым числом, следовательно, его значение передается функции postMessage, отправляющей сообщение событию onmessage объекта, который установил этот рабочий веб-процесс.
Результат выглядит следующим образом:
Текущее самое большое простое число: 30477191


Вот вторая часть программы. Которая запускается через браузер. К слову, у меня mozila до конца цикла не доходит, падает.
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
<!DOCTYPE html>
<html> <!-- webworkers.html -->
  <head>
    <title>Web Workers</title>
    <script src='OSC.js'></script>
  </head>
  <body>
    Current highest prime number:
    <span id='result'>0</span>
 
    <script>
      if (!!window.Worker)
      {
        var worker = new Worker('worker.js')
 
        worker.onmessage = function (event)
        {
          O('result').innerHTML = event.data;
        }
      }
      else
      {
        alert("Web workers not supported")
      }
    </script>
  </body>
</html>
А это OSC. Если кто захочет запустить посмотреть.
JavaScript
1
2
3
function O(i) { return typeof i == 'object' ? i : document.getElementById(i) }
function S(i) { return O(i).style                                            }
function C(i) { return document.getElementsByClassName(i)                    }
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.10.2017, 20:17
Ответы с готовыми решениями:

Поиск простых чисел
Здравствуйте. Мне нужен бытсрый алгоритм для нахождения n первых простых чисел (n &lt;= 3 * 10 ^ 7). Ограничение по времени - 1 секунда....

Поиск простых чисел
Существует универсальная шкала (линейка) для поиска (измерения) простых чисел. К сожалению размер этой шкалы (линейки) возрастает...

Количество простых чисел
Как найти количество простых чисел в промежутке за 2 секунды? Приметка: &quot;10Е12&quot; - десять в степени двенадцать.

14
Модератор
Эксперт функциональных языков программирования
3134 / 2281 / 469
Регистрация: 26.03.2015
Сообщений: 8,878
21.10.2017, 14:53
Цитата Сообщение от freeman86 Посмотреть сообщение
Ведь, как минимум часть i <= Math.sqrt(n) никогда не будет true, так как i всегда будет больше n на единицу...
Почему i будет больше n?
n - это число, которое мы проверяем на простоту
i - это числа, которые могут быть делителями числа n

на первой итерации цикла while n равно 2, поэтому во внутренний цикл for мы не зайдём
но, начиная с третьей итерации внешнего цикла, мы будем заходить во внутренний цикл
1
0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98
21.10.2017, 22:37  [ТС]
Shamil1, а почему мы не зайдем во внутренний цикл for сразу, а только с третьей итерации?
0
Модератор
Эксперт функциональных языков программирования
3134 / 2281 / 469
Регистрация: 26.03.2015
Сообщений: 8,878
22.10.2017, 00:32
Цитата Сообщение от freeman86 Посмотреть сообщение
а почему мы не зайдем во внутренний цикл for сразу, а только с третьей итерации?
Потому что в начале цикла i = 2. Для n = 2 и n = 3 не выполняется условие "i <= Math.sqrt(n)".
1
0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98
22.10.2017, 20:57  [ТС]
Это я понимаю. Но если нет захода в for, разве будет заход в if в данном случае? Или сразу после невыполнения i <= Math.sqrt(n) идет выполнение postMessage(n)?
0
Модератор
Эксперт функциональных языков программирования
3134 / 2281 / 469
Регистрация: 26.03.2015
Сообщений: 8,878
22.10.2017, 23:03
Цитата Сообщение от freeman86 Посмотреть сообщение
Но если нет захода в for, разве будет заход в if в данном случае?
Не будет.

Цитата Сообщение от freeman86 Посмотреть сообщение
Или сразу после невыполнения i <= Math.sqrt(n) идет выполнение postMessage(n)?
Да.

Цитата Сообщение от freeman86 Посмотреть сообщение
Он должен пропускать простые числа
Алгоритм, наоборот, пропускает составные числа.
1
0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98
22.10.2017, 23:40  [ТС]
При достижении n = 4, i увеличивается на единицу, и таким остается до следующего составного числа, а там увеличивается еще на единицу?

А как, например, с числом 6? В цикле for оно не проходит, так как 3 <= 2.45. Но ведь оно составное, так как 6/1, 6/2 и 6/6 без остатка!
0
Модератор
Эксперт функциональных языков программирования
3134 / 2281 / 469
Регистрация: 26.03.2015
Сообщений: 8,878
23.10.2017, 13:51
внешний цикл перебирает n - числа, которые мы хотим проверить на простоту
внутренний цикл перебирает i - числа, на которые мы делим проверяемое число
за пределами внутреннего цикла i не определено

для каждого нового n мы сначала устанавливаем i = 2, а потом начинаем увеличивать i на 1, пока оно не станет слишком большим
после этого переходим к следующему n
1
0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98
23.10.2017, 20:45  [ТС]
Теперь понятно! Значит, после каждой итерации цикла while, с заходом в for, i возвращается на 2 и проверка начинается с 2, а потом возрастает пока не упрется в i <= Math.sqrt(n). Просто я раньше не сталкивался с циклами, вложенными один в другой. А если бы i была определена за пределами for, например там же, где n, чтобы это изменило?
0
Модератор
Эксперт функциональных языков программирования
3134 / 2281 / 469
Регистрация: 26.03.2015
Сообщений: 8,878
24.10.2017, 13:54
Цитата Сообщение от freeman86 Посмотреть сообщение
после каждой итерации цикла while, с заходом в for, i возвращается на 2 и проверка начинается с 2, а потом возрастает пока не упрется в i <= Math.sqrt(n)
Да.

Цитата Сообщение от freeman86 Посмотреть сообщение
А если бы i была определена за пределами for, например там же, где n, чтобы это изменило?
В данном случае, нет, так как выполнение цикла начинается с "i = 2".

Вот тут простым языком написано про цикл for:
https://learn.javascript.ru/while-for
1
0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98
24.10.2017, 19:51  [ТС]
Спасибо! A какой математический смысл i <= Math.sqrt(n)? Зачем извлекать корень из n и сравнивать его с i?
0
Модератор
Эксперт функциональных языков программирования
3134 / 2281 / 469
Регистрация: 26.03.2015
Сообщений: 8,878
24.10.2017, 21:51
Цитата Сообщение от freeman86 Посмотреть сообщение
Зачем извлекать корень из n и сравнивать его с i?
Мы проверяем, является ли i множителем числа n. То есть, существует ли такое число j, что i * j == n. Так как мы проверяем по порядку, начиная с 2, то нам достаточно искать такие i, что i <= j. Если i > j, то мы раньше найдём j и закончим проверку этого числа n. Меньший из сомножителей не может быть больше квадратного корня из n, поэтому дальше проверять не надо.
1
 Аватар для oldnick85
36 / 34 / 10
Регистрация: 15.07.2017
Сообщений: 128
28.10.2017, 01:30
Небольшое замечание: i <= Math.sqrt(n) лучше использовать в виде i<= sq_n, а sq_n вычислять перед этим вне цикла, чисто для ускорения работы.
1
0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98
28.10.2017, 22:28  [ТС]
oldnick85, а почему так, как вы предлагаете, будет быстрее работать. Мне просто интересно для общего развития.
0
Модератор
Эксперт функциональных языков программирования
3134 / 2281 / 469
Регистрация: 26.03.2015
Сообщений: 8,878
29.10.2017, 15:26
Цитата Сообщение от freeman86 Посмотреть сообщение
а почему так, как вы предлагаете, будет быстрее работать
Math.sqrt(n) будет вычисляться один раз перед внутренним циклом, а не на каждой итерации (при каждой проверке условия). Нормальные компиляторы выполняют эту оптимизацию самостоятельно. Но, вероятно, интерпретатор JavaScript не умеет выполнять такую оптимизацию. Так что совет oldnick85 дал хороший.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
29.10.2017, 15:26
Помогаю со студенческими работами здесь

Генерация простых чисел
Нашел сам алгоритм создания (а не вычисления перебором) очень больших простых чисел. Где можно найти список всех известных формул для...

Алгоритм поиска n простых чисел
Помогите, пожалуйста, составить батник, находящий простые числа в заданном интервале.

Алгоритм поиска целых простых чисел
Предлагаю простой алгоритм проверки и поиска простых чисел, приглашаю к сотрудничеству в написании программы для его реализации,...

Разложение числа на сумму простых чисел
подскажите плз алгоритм)

Алгоритм поиска количества простых чисел в заданном массиве
алгоритм поиск количества простых чисел в заданном целочисленном массиве из 50 элементов. Помогите написать(


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
15
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Обработчик клика мыши в браузере ПК и касания экрана в браузере на мобильном устройстве
8Observer8 02.02.2026
Содержание блога Для начала пошагово создадим рабочий пример для подготовки к экспериментам в браузере ПК и в браузере мобильного устройства. Потом напишем обработчик клика мыши и обработчик. . .
Философия технологии
iceja 01.02.2026
На мой взгляд у человека в технических проектах остается роль генерального директора. Все остальное нейронки делают уже лучше человека. Они не могут нести предпринимательские риски, не могут. . .
SDL3 для Web (WebAssembly): Вывод текста со шрифтом TTF с помощью SDL3_ttf
8Observer8 01.02.2026
Содержание блога В этой пошаговой инструкции создадим с нуля веб-приложение, которое выводит текст в окне браузера. Запустим на Android на локальном сервере. Загрузим Release на бесплатный. . .
SDL3 для Web (WebAssembly): Сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
SDL3 для Web (WebAssembly): Установка Emscripten SDK (emsdk) и CMake для сборки C и C++ приложений в Wasm
8Observer8 30.01.2026
Содержание блога Для того чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. . . .
SDL3 для Android: Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
SDL3 для Android: Загрузка PNG с альфа-каналом с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru