Задать вопрос
@Sheephard

Как избавиться от переполнения в модуле math?

Решаю задачу по учёбе.
Получаю ошибку OverflowError: math range error.
from math import *


def get_b(p, a):
    start_time = time.time()
    # b = math.fmod(math.pow(a, p-2), p)

    b = pow(a, p-2)
    b = b % p
    print("--- %s seconds ---" % (time.time() - start_time))
    return int(b)

print(get_b(2097151, 9))


Как решить проблему?

Без модуля math всё работает, но я не укладываюсь во время. Я пробовала написать свою реализацию возведения в степень на Python, но она не даёт выигрыша во времени.

Думаю, что ошибка в том, что модуль работает во float. Если это так, то как его заставить его работать с int?
  • Вопрос задан
  • 887 просмотров
Подписаться 1 Простой 4 комментария
Решения вопроса 1
@galaxy
powmod пишете?


pow(x, y[, z])

Return x to the power y; if z is present, return x to the power y, modulo z (computed more efficiently than pow(x, y) % z). The two-argument form pow(x, y) is equivalent to using the power operator: x**y.
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Greenway Global Новосибирск
от 150 000 ₽
SpectrumData Екатеринбург
от 200 000 до 300 000 ₽
AST Москва
До 350 000 ₽