Форум программистов, компьютерный форум, киберфорум
Python для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.60/25: Рейтинг темы: голосов - 25, средняя оценка - 4.60
 Аватар для MSP_cyber
18 / 16 / 4
Регистрация: 29.03.2015
Сообщений: 100

Рекурсия. Определить, является ли натуральное число простым

29.06.2021, 20:41. Показов 5591. Ответов 1

Студворк — интернет-сервис помощи студентам
Напишите рекурсивную программу, которая определяет, является ли переданное ей натуральное число простым.
Программа должна вывести слово 'YES', если переданное ей число – простое, и слово 'NO' в противном случае.

Вот код, который мне удалось написать.
На тестирующей системе из 22 тестов 5 не проходят.
В чём дело - не пойму.

Пожалуйста, посмотрите код, есть, наверное, ошибки, или просто что-то не так:
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
def prostoe (d) :
  # d - делитель числа N
  
  if d > last_d :
    return 0
  
  if N % d == 0 :
    return 1
  else :
    return prostoe (d + 1)
 
N = int (input ())
 
last_d = int (N ** 0.5)
# делители, равные 1 и N не проверяем
d = 2
 
if N == 1 :
  print ('NO')
elif prostoe (d) == 0 :
  print ('YES')
else :
  print ('NO')
Может быть у вас есть другое решение, более быстрое.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
29.06.2021, 20:41
Ответы с готовыми решениями:

Определить, является ли число простым
Напишите логическую функцию logi(x), определяющую, является ли заданное натуральное число x простым. Если число простое, то функция должна...

Определить является ли число простым
2) Написать функцию, определяющую, является ли число простым.

Определить является ли число простым
выдает ошибку в строке if def prost(n): d = 2 while n % d != 0: d += 1 print(d == n) return d == n if _name_...

1
Эксперт Python
8840 / 4492 / 1864
Регистрация: 27.03.2020
Сообщений: 7,312
29.06.2021, 21:12
MSP_cyber,
Python
1
2
3
4
5
6
def isPrime(num, ans = 2):
    if num < ans*ans:
        return True
    if num % ans == 0:
        return False
    return isPrime(num, ans + 1)
2
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
29.06.2021, 21:12
Помогаю со студенческими работами здесь

Определить, является ли число простым
import math n=int(input()) f=True for i in range(2, round(math.sqrt(n))+1): if (n%i==0): f=False break if (f): ...

Дано натуральное число. Выяснить, является ли оно простым. Инструкцию цикла с параметром не использовать
Дано натуральное число. Выяснить, является ли оно простым. Инструкцию цикла с параметром не использовать.

Определить является ли заданное число простым
Составьте программу, который выдает 1, если заданное число простое и 0 – в противном случае. Число называется простым, если все его...

Рекурсия: определить, является ли заданное натуральное число простым
Написать рекурсивную функцию, определяющую, является ли заданное натуральное число простым. #include &lt;stdio.h&gt; int x; void...

Рекурсия: определить, является ли заданное натуральное число простым
1. Написать функцию определения, является ли заданное натуральное число простым.


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru