栏目分类:
子分类:
返回
文库吧用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
文库吧 > IT > 软件开发 > 后端开发 > C/C++/C#

C语言练习题 —— 实现n的k次方(函数递归)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C语言练习题 —— 实现n的k次方(函数递归)

题目描述:

        输入一个数(n) , 在输入另外一个数(k)作为(n)的次方

输入示例:

        例如:3 的 2 次方

输出示例:

        243

代码实现:
double Pow(int n, int k)
{
    if (k == 0)
    {
        return 1.0;
    }
    else if (k > 0)
    {
        return n * Pow(n, k - 1);
    }
    else
    {
        return 1.0 / (Pow(n, -k));
    }
}

int main()
{
    int n = 0, k = 0;

    scanf("%d%d", &n, &k);
    printf("n = %d  k = %dn", n, k);

    double ret = Pow(n, k);
    printf("%lfn", ret);
    return 0;
}
代码详解:

        1、将读入的数字传入Pow函数中

        2、当k为0时,任何数的0次方都等于1

        3、当k等于2时,将使用函数递归,每次递归k-1,当k=0时,递归结束

        4、当k为负数时,递归结构同正数一样,返回类型为double

图解:(红色为递归路线,绿色为返回值路线)
转载请注明:文章转载自 www.wk8.com.cn
本文地址:https://www.wk8.com.cn/it/1038138.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 wk8.com.cn

ICP备案号:晋ICP备2021003244-6号