|
0 / 0 / 0
Регистрация: 20.07.2016
Сообщений: 98
|
||||||||||||||||
Список простых чисел20.10.2017, 20:17. Показов 1259. Ответов 14
Метки нет (Все метки)
Чтобы не плодить темы, решил спросить тут. Вот кусок программы, он на JS, но это не важно. Он должен пропускать простые числа(те, которые делятся без остатка только на 1 и на себя), и записывать в счетчик составные. Сама программа работает, но я всю голову сломал почему она работает! Ведь, как минимум часть i <= Math.sqrt(n) никогда не будет true, так как i всегда будет больше n на единицу...
я в программировании новичек, но вроде бы с циклом for разобрался. А тут что-то непонятное. Во вторых, зачем извлекать корень квадратный...![]()
Но если все возможные сомножители будут протестированы и не будет найден результат с нулевым остатком, то n должно быть простым числом, следовательно, его значение передается функции postMessage, отправляющей сообщение событию onmessage объекта, который установил этот рабочий веб-процесс. Результат выглядит следующим образом: Текущее самое большое простое число: 30477191 Вот вторая часть программы. Которая запускается через браузер. К слову, у меня mozila до конца цикла не доходит, падает.
![]()
0
|
||||||||||||||||
| 20.10.2017, 20:17 | |
|
Ответы с готовыми решениями:
14
Поиск простых чисел Поиск простых чисел Количество простых чисел |
|
Модератор
3137 / 2284 / 469
Регистрация: 26.03.2015
Сообщений: 8,888
|
||
| 21.10.2017, 14:53 | ||
|
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 | ||
|
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 | ||||
|
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 | |||
|
Вот тут простым языком написано про цикл 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 | ||
|
1
|
||
|
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 | ||
|
1
|
||
| 29.10.2017, 15:26 | |
|
Помогаю со студенческими работами здесь
15
Генерация простых чисел Алгоритм поиска n простых чисел Алгоритм поиска целых простых чисел Разложение числа на сумму простых чисел Алгоритм поиска количества простых чисел в заданном массиве Искать еще темы с ответами Или воспользуйтесь поиском по форуму: |
|
| Опции темы | |
|
|
Новые блоги и статьи
|
|||
|
Отчёт о затраченных материалах за определенный период с макетом печатной формы
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
Потому что они ждут. Ждут выходных, ждут отпуска, ждут удачного момента. . .
а удачный момент так и не приходит.
|