小编Jur*_*ofs的帖子

如何找到一系列n*0.1(在Python中)最接近反对数(10base)的每个整数

在我的算法中,我想评估当前整数n是否恰好最接近0.1的任何正数的反对数,所以0.1,1.0,1.1,7.9,21.5等.

反对数?AntiLog(x)= 10 x

我找到了一个在线计算器,可以在这里找到antilog:http://ncalculators.com/number-conversion/anti-log-logarithm-calculator.htm但我无处可以找到任何用Python或任何其他编程语言执行此操作的示例.

如果我不能使用Python来查找一系列数字的反对数,我将不得不求助于在我的程序中存储一个反对数值列表,为了性能,我可能会考虑到这一点,但不管怎么说它很好.如何在代码中执行此操作.

更新: 使用第一个答案的代码,我能够做到这一点,这段代码完全展示了我想要做的所有事情:

#!/usr/bin/python
import sys
import math

for x in xrange(1, 1000000):
    target = round(math.log10(x),1)
    int_antilog = int(10**target+0.5) #fast round() alternative
    if (x == int_antilog):
        print 'do something at call ' + str(x)
Run Code Online (Sandbox Code Playgroud)

python algorithm logarithm

3
推荐指数
1
解决办法
2145
查看次数

标签 统计

algorithm ×1

logarithm ×1

python ×1