Я пытаюсь найти самый большой корень куба, который является целым числом, которое составляет менее 12 000.
processing = True
n = 12000
while processing:
n -= 1
if n ** (1/3) == #checks to see if this has decimals or not
Я не уверен, как проверить, если это целое число или нет! Я мог бы преобразовать его в строку, а затем использовать индексирование, чтобы проверить конечные значения и посмотреть, равны ли они нулю или нет, хотя это кажется довольно громоздким. Есть ли более простой способ?
python
floating-point
тяпка ничья lion4
источник
источник
Ответы:
Чтобы проверить, является ли значение с плавающей точкой целым числом, используйте
float.is_integer()
метод :Метод был добавлен в
float
тип в Python 2.6.Учтите, что в Python 2
1/3
есть0
(деление по полу для целочисленных операндов!), И что арифметика с плавающей запятой может быть неточной (afloat
- это приближение, использующее двоичные дроби, а не точное действительное число). Но немного подкорректировав цикл, вы получите:Это означает, что что-либо более 3 кубов (включая 10648) было пропущено из-за вышеупомянутой неточности:
Вместо этого вам придется проверять номера, близкие к целому, или не использовать их
float()
для поиска своего номера. Как округление корня куба12000
:Если вы используете Python 3.5 или новее, вы можете использовать
math.isclose()
функцию, чтобы увидеть, находится ли значение с плавающей запятой в пределах настраиваемого поля:Для более старых версий наивная реализация этой функции (пропуск проверки ошибок и игнорирование бесконечности и NaN), как упомянуто в PEP485 :
источник
True
если нет десятичных дробей вообще. Конечно, со стороны ОП может быть неправильное понимание арифметики и точности с плавающей запятой.1.0000000000000001
отображается как1.0
, в 3 показано самое короткое строковое представление, которое дает то же значение.range(12000, -1, -1)
могли бы быть (лучше, точнее) переписаны какreversed(range(12000+1))
Мы можем использовать оператор по модулю (%). Это говорит нам, сколько у нас осталось, когда мы делим x на y - выражается как
x % y
. Каждое целое число должно делиться на 1, поэтому, если есть остаток, он не должен быть целым числом.Эта функция возвращает логическое значение
True
илиFalse
, в зависимости от того,n
является ли целое число.источник
Вы можете использовать это:
источник
.is_integer()
продолжает работать.is_integer
использует аналогичный метод (o = (floor(x) == x) ? Py_True : Py_False;
). Но я согласен, нужно использовать, такis_integer()
как это намного понятнее.large_float == large_int
Е. Может потерпеть неудачу, даже еслиlarge_float == float(large_int)
.123456789012345678901234567890.0 != 123456789012345678901234567890
но123456789012345678901234567890.0 == float(123456789012345678901234567890)
k = 123456789012345678901234567890.0
тогдаk == int(k)
это правда, что является правильным ответом.Вам не нужно ничего зацикливать или проверять. Просто возьмите кубический корень из 12 000 и округлите его:
источник
Вы можете использовать операцию по модулю для этого.
источник
n
6.2, 6.0, 6.12312412, у всех нас есть"We have a decimal number here!"
?Не проще ли проверить корни куба? Начните с 20 (20 ** 3 = 8000) и до 30 (30 ** 3 = 27000). Затем вам нужно проверить менее 10 целых чисел.
источник
n**(1/3)
целое число. Например, на моем компьютере `10648 ** (1/3) = 21.999999999999996` вместо22
: проблема! С этим методом ответа такой проблемы нет. Я думаю, что это единственно правильное решение с математической точки зрения (другие решения являются Python-правильными).Как насчет
источник
Приведенные выше ответы работают для многих случаев, но они пропускают некоторые. Учтите следующее:
Используя это в качестве эталона, некоторые другие предложения не получают желаемого поведения:
Вместо этого попробуйте:
теперь мы получаем:
isclose
поставляется с Python 3.5+ , а для других Python вы можете использовать это в основном эквивалентное определение (как упомянуто в соответствующем PEP )источник
math.fsum([0.1] * 10) == 1
Просто дополнительная информация,
is_integer
внутренне:источник
Все ответы хороши, но надежный метод огня будет
Функция возвращает True, если это целое число, иначе False .... Я знаю, что немного опоздал, но вот один из интересных методов, которые я сделал ...
Изменить: как указано в комментарии ниже, более дешевый эквивалентный тест будет:
источник
n % 1 == 0
. В этом случае вы выполняете две операции, которые стоят дороже для более дешевого эквивалентного теста.источник
Попробуйте использовать:
Это даст намного больше точности, чем любые другие методы.
источник
Вы можете использовать
round
функцию для вычисления значения.Да, в python, как указывали многие, когда мы вычисляем значение корня куба, он выдаст вам вывод с небольшой ошибкой. Чтобы проверить, является ли значение целым числом, вы можете использовать следующую функцию:
Но помните, что
int(n)
это эквивалентноmath.floor
и из-за этого, если вы найдете,int(41063625**(1.0/3.0))
вы получите 344 вместо 345.Поэтому, пожалуйста, будьте осторожны при использовании
int
кубических корней.источник