Найти - Пользователи
Полная версия: Как ускорить код?
Начало » Python для новичков » Как ускорить код?
1
AndreyNill
Здравствуйте! Написал код по поиску простого числа, на сайте, для которого он написан, не проходит по времени и прерывается. Как мне отредактировать данный код, чтобы не было данной проблемы?


  import math
import random
def is_prime(n):
    if n % 2 == 0 and n > 2:
        return False
    return all(n % i for i in range(3, int(math.sqrt(n)) + 1, 2))
k = int(input())
number = 2
i = 0
while True:
    if is_prime(number):
        i += 1
        if i == k:
            break
    number += 1
print(number)
PEHDOM
э-э-э а вы уверены что ваш код вообще работает правильно? Я вот запустил его, ввел 4 а мне ваша программа выдала 7. WTF?
по теме есть туева хуча статей, почитайте например вот эту https://habr.com/ru/post/122538/
marvellik
а что вообще вы делаете?
 k = int(input())
number = 2
i = 0
while True:
    if is_prime(number):
        i += 1
        if i == k:
            break
    number += 1
print(number)
представьте я введу в k число 24. это не простое число. значить условие
if is_prime(number) не выполниться никогда и мы получаем бесконечный цикл. но в функцию вы подаете number который равен 2 и условие if n % 2 == 0 верно значить функция вернет фальш и мы опять получаем бесконечный цикл
This is a "lo-fi" version of our main content. To view the full version with more information, formatting and images, please click here.
Powered by DjangoBB