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

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

反对数?

AntiLog(x)= 10x

如果我不能使用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)

解决方法:

Python有一个power operator执行你想要的取幂:

def antilog(x):

return 10 ** x

例子:

>>> antilog(0.1)

1.2589254117941673

>>> antilog(3)

1000

>>> inputs = [0.1, 1.0, 1.1, 7.9, 21.5]

>>> outputs = [antilog(x) for x in inputs]

>>> print outputs

[1.2589254117941673, 10.0, 12.589254117941675, 79432823.47242822, 3.1622776601683794e+21]

回合并以您喜欢的方式转换为整数,您将会很高兴.

标签:logarithm,python,algorithm

来源: https://codeday.me/bug/20190825/1721562.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值