C primer plus 第九章 练习8:
/*
============================================================
    使用递归函数重做练习7.
============================================================
*/

#include <stdio.h>
double power(double n, int p);
int main(void)
{
    double n;
    int p;

    printf("Enter a number and the positive integer power to which\n");
    printf(" the number will be raised. Enter q to quit.\n");
    while(scanf_s("%lf %d", &n, &p) == 2)
    {
        printf("%g to the power %d is %g\n", n, p, power(n, p));
        printf("Enter next pair of numbers or q to quit.\n");
    }
    printf("Hope you enjoyed this power trip -- bye!\n");
    return 0;
}

double power(double n, int p)
{
    double pow;
    if(n == 0) return 0;
    else if(p == 0) return 1;
    else if(p > 0) {
        pow = n * power(n, p-1);
        return pow;
    }
    else if(p < 0) {
        pow = power(n, p+1) / n;
        return pow;
    }
}
阅读更多
个人分类: 练习题
想对作者说点什么? 我来说一句

C++PrimerPlus 课后编程练习答案

2016年08月31日 106KB 下载

没有更多推荐了,返回首页

不良信息举报

C primer plus 第九章 练习8:

最多只允许输入30个字

加入CSDN,享受更精准的内容推荐,与500万程序员共同成长!
关闭
关闭