当前位置: 首页 > 图灵资讯 > 行业资讯> python中pow如何使用内置调用?

python中pow如何使用内置调用?

来源:图灵python
时间: 2024-10-09 18:17:52

我们在用函数调用的时候一般是要考虑函数的返回值,其次就是参数的问题。相信经过之前几篇参数文章的讲解,大部分小伙伴已经对参数不陌生了。那么今天我们就来讲讲常见返回值的问题。这里以pow函数的调用为例,在学习使用方法的同时,我们会试着找寻内置调用返回值得结果以及进行结果分析。

pow() 方法返回 xy(x 的 y 次方) 的值。

math 模块 pow() 方法的语法:

importmath
math.pow(x,y)

内置的 pow() 方法:

pow(x,y[,z])

函数是计算 x 的 y 次方,如果 z 在存在,则再对结果进行取模,其结果等效于 pow(x,y) %z。

注意:pow() 通过内置的方法直接调用,内置方法会把参数作为整型,而 math 模块则会把参数转换为 float。

举例:

#pow(base,exp[,mod])

#powpowerexpexponentmodmodule

#返回base的exp次幂;如果mod存在,则返回base的exp次幂对mod取余(比pow(base,exp)%mod更高效)。两参数形式pow(base,exp)等价于乘方运算符:base**exp。

#返回base的exp次幂;
print(f'{pow(2,3)=}')
print(f'{pow(10,2)=}')
#两参数形式pow(base,exp)等价于乘方运算符:base**exp。
print(f'{2**3=}')
print(f'{10**2=}')
#如果mod存在,则返回base的exp次幂对mod取余(比pow(base,exp)%mod更高效)
#如果mod存在,会使用快速幂取模的算法来取模
importtime
start=time.time()
print(f'{pow(1234,1234567,67)=}')
end=time.time()
print(f'耗时:{end-start=}')
#start=time.time()
#print(f'{pow(1234,1234567)%67=}')
#end=time.time()
#print(f'耗时:{end-start=}')
#
#参数必须具有数值类型。对于混用的操作数类型,则将应用双目算术运算符的类型强制转换规则。对于int操作数,结果具有与操作数相同的类型(强制转换后),除非第二个参数为负值;在这种情况下,所有参数将被转换为浮点数并输出浮点数结果。例如,10**2返回100,但10**-2返回0.01。

#参数必须具有数值类型
#print(f'{pow(2,"3")=}')
#对于混用的操作数类型,则将应用双目算术运算符的类型强制转换规则。
print(f'{pow(2.0,3)=}')
#对于int操作数,结果具有与操作数相同的类型(强制转换后),除非第二个参数为负值;在这种情况下,所有参数将被转换为浮点数并输出浮点数结果。
print(f'{pow(2,3)=}')
print(f'{pow(2,-3)=}')
#
#对于int操作数base和exp,如果给出mod,则mod必须为整数类型并且mod必须不为零。如果给出mod并且exp为负值,则base必须相对于mod不可整除。在这种情况下,将会返回pow(inv_base,-exp,mod),其中inv_base为base的倒数对mod取余。
#

#对于int操作数base和exp,如果给出mod,则mod必须为整数类型并且mod必须不为零。
#print(f'{pow(2,3,0)=}')

#下面的例子是38的倒数对97取余:
#
#>>>
#>>>pow(38,-1,mod=97)
#23
#>>>23*38%97==1
#True
#在3.8版更改:对于int操作数,三参数形式的pow现在允许第二个参数为负值,即可以计算倒数的余数。
#
#在3.8版更改:允许关键字参数。之前只支持位置参数。

以上就是python中pow函数使用内置调用的方法,最后对于参数的输出和math有所不同,这点需要引起大家的注意。