面试题11:数值的整数次方

来源:互联网 发布:线割编程 编辑:程序博客网 时间:2024/06/07 06:38

这个问题我想很多人拿到之后直接设置一个for循环,让底数自乘次方和次数就行。但是没有考虑到底数是0、指数是0、以及指数是负数的情况


源码

#coding:utf-8# 不得使用库函数,实现数值的整数次方def Power(base, exponent):    answer = 1.0    if isEqualToZero(base, 0.0) == True:        return False    if exponent > 0:        for i in range(exponent):            answer *= base        return answer    elif exponent == 0:        return 0    elif exponent < 0:        for i in range(exponent):            answer *= base        return 1/answerdef isEqualToZero(num1, num2): # 不能直接用==判断两个小数是否相等,两个小数的差值很小才能认为它们相等    if (num1 - num2 < 0.0000001) and (num2 - num1 < 0.0000001):        return True    else:        return Falseprint Power(5, 4)print Power(0, -1)

这里面还有个要注意的

c语言中,计算机表示小数会有误差,我们不能直接用‘==’判断两个小数是否相等,如果两个小数的绝对值小于0.00000001才能认为是相等,这个在代码中已经体现了。(但是Python没有这么矫情,可以准确的判断两个小数是否相等,但我在源码中依旧加入了这个模块)

0 0
原创粉丝点击