Этаж натурального логарифмаPython

Программы на Python
Ответить
Anonymous
 Этаж натурального логарифма

Сообщение Anonymous »

У меня есть сколь угодно большое целое число n. Как мне рассчитать точное значение ⌊ln()⌋?

Код: Выделить всё

int(math.log(n))
не работает, так как math.log(n) может быть недостаточно точным (например, если задано 4311231547115195, он выводит 36, но должен вывести 35).
Я знаю, что ⌊ln()⌋ либо ⌊

Код: Выделить всё

n.bit_length()-1
ln(2)⌋ или ⌊

Код: Выделить всё

n.bit_length()
ln(2)⌋. Однако, помимо той же проблемы с точностью чисел с плавающей запятой, если они не равны, я не знаю, какой из них выбрать.
Я также пытался вычислить нижнюю и верхнюю границы значения n.bit_length()ln(2). Я попробовал просто использовать рациональные аппроксимации ln(2), заданные гармоническим рядом. Однако знакопеременный гармонический ряд сходится очень медленно, и в некоторых случаях требуется очень много времени, чтобы значения приблизились достаточно близко, чтобы я мог определить ⌊

Код: Выделить всё

n.bit_length()
ln(2)⌋ и ⌊

Код: Выделить всё

n.bit_length()-1
ln(2)⌋, и я до сих пор не знаю, что делать, если они неравны.
Я также был бы признателен за решения для ⌊ln()2⌋, ⌊ln()3⌋ и ⌊ln()4⌋.

Подробнее здесь: https://stackoverflow.com/questions/798 ... -logarithm
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «Python»