分数 5
作者 C课程组
单位 浙江大学
本题要求实现一个计算xn(n≥1)的函数。
函数接口定义:
double calc_pow( double x, int n );
函数calc_pow
应返回x
的n
次幂的值。建议用递归实现。题目保证结果在双精度范围内。
裁判测试程序样例:
#include <stdio.h>
double calc_pow( double x, int n );
int main()
{
double x;
int n;
scanf("%lf %d", &x, &n);
printf("%.0f\n", calc_pow(x, n));
return 0;
}
/* 你的代码将被嵌在这里 */
输入样例:
2 3
输出样例:
8
代码长度限制
16 KB
时间限制
400 ms
内存限制
64 MB
C程序如下:
// 计算 x 的 n 次幂的递归函数
double calc_pow(double x, int n) {
// 如果 n 等于 1,直接返回 x(因为任何数的1次幂都是它本身)
if(n == 1){
return x;
}
// 否则,返回 x 乘以 x 的 (n-1) 次幂(通过递归调用 calc_pow 实现)
// 这里递归调用会逐步减小 n 的值,直到 n 变为 1,然后递归会逐层返回结果
return x * calc_pow(x, n - 1);
}