0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98

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

20.10.2017, 20:17. Показов 1259. Ответов 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
Модератор
Эксперт функциональных языков программирования
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
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
Модератор
Эксперт функциональных языков программирования
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
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
Модератор
Эксперт функциональных языков программирования
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
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
Модератор
Эксперт функциональных языков программирования
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
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
Модератор
Эксперт функциональных языков программирования
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
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
Модератор
Эксперт функциональных языков программирования
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
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
Модератор
Эксперт функциональных языков программирования
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
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
Ответ Создать тему
Опции темы

Новые блоги и статьи
Отчёт о затраченных материалах за определенный период с макетом печатной формы
Maks 21.04.2026
Отчёт из решения ниже размещён в конфигурации КА2. Задача: разработка отчёта по затраченным материалам за определённый период, с возможностью вывода печатной формы отчёта с шапкой и подвалом. В. . .
Отчёт о спецтехнике находящейся в ремонте
Maks 20.04.2026
Отчёт из решения ниже размещен в конфигурации КА2. Задача: отобразить спецтехнику, которая на данный момент находится в ремонте. Есть нетиповой документ "Заявка на ремонт спецтехники" который. . .
Памятка для бота и "визитка" для читателей "Semantic Universe Layer (Слой семантической вселенной)"
Hrethgir 19.04.2026
Сгенерировано для краткого описания по случаю сборки и компиляции скелета серверного приложения. И пусть после этого скажут, что статьи сгенерированные AI - туфта и не интересно. И это не реклама -. . .
Запрет удаления строк ТЧ документа при определённом условии
Maks 19.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "Аккумуляторы", разработанного в конфигурации КА2. У данного документа есть ТЧ, в которой в зависимости от прав доступа. . .
Модель заражения группы наркоманов
alhaos 17.04.2026
Условия задачи сформулированы тут Суть: - Группа наркоманов из 10 человек. - Только один инфицирован ВИЧ. - Колются одной иглой. - Колются раз в день. - Колются последовательно через. . .
Мысли в слух. Про "навсегда".
kumehtar 16.04.2026
Подумалось тут, что наверное очень глупо использовать во всяких своих установках понятие "навсегда". Это очень сильное понятие, и я только начинаю понимать край его смысла, не смотря на то что давно. . .
My Business CRM
MaGz GoLd 16.04.2026
Всем привет, недавно возникла потребность создать CRM, для личных нужд. Собственно программа предоставляет из себя базу данных клиентов, в которой можно фиксировать звонки, стадии сделки, а также. . .
Знаешь почему 90% людей редко бывают счастливыми?
kumehtar 14.04.2026
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . . а удачный момент так и не приходит.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru