自己写一个pow()函数

问题:请自己动手写一个pow()函数。

  我们在学习C语言的时候,可能已经接触过pow()函数,它是C语言标准库函数中自带的一个函数,使用的时候只需包含<math.h>就可以了,不需要你自己动手去实现。

  在C语言标准库函数中,pow()函数是这样声明的double pow(double x, double y),其作用就是返回x的y次幂。幂函数的实现还是比较简单的,我们就自己动手写一个:

func challenge(number: Int, power: Int) -> Int {
    
    // 对输入的数据进行校验,确保底数和幂指数都是有意义的
    guard number > 0, power > 0 else { return 0 }
    
    // 初始化返回值,默认其值为底数
    var returnValue = number
    
    for _ in 1..<power {
        
        // 返回值 = 底数 * 底数(一共执行power-1次)
        returnValue *= number
    }
    
    // 返回最后的结果
    return returnValue
}

challenge(number: 2, power: 3)  // 结果为8

  除了上面那种解决方案之外,还可以使用递归算法,这样看上去可以让代码更简洁:

func challenge1(number: Int, power: Int) -> Int {
    guard number > 0, power > 0 else { return 0 }
    
    // 如果幂指数为1,直接返回底数
    if power == 1 { return number }
    
    // 当幂指数不为1时,直接返回底数的power - 1次方
    return number * challenge1(number: number, power: power - 1)
}

challenge1(number: 2, power: 5)  // 结果为32
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

友情链接更多精彩内容