1.函数形式
double pow( double x, double y );
解析:传给这个函数两个double类型的参数,返回的是一个double类型的数值(虽说参数是double类型的,但事实上也是可以传整型的,因为会隐性算术转换)
2.头文件
#include <math.h>
3.作用
实现指数的计算(即x的y次方)
ps.最大计算的数值不能超过2的64次方
4.举例
4.1返回类型是否可以由其他类型接受?
//计算2的16次方
#include <stdio.h>
#include <math.h>
int main()
{
int x = 0;
int y = 0;
scanf("%d %d", &x, &y);
int ret = pow(x, y); //返回类型是double,这里用int接受
printf("%d", ret);
return 0;
}
可以
4.2 printf函数打印,可不可以用其他类型来打印
//计算2的16次方
#include <stdio.h>
#include <math.h>
int main()
{
int x = 0;
int y = 0;
scanf("%d %d", &x, &y);
int ret = pow(x, y);
printf("%lf", ret); //ret是整型,但是printf这边用%lf打印
return 0;
}
这种时候,可以通过“强制类型转化”来解决
#include <stdio.h>
#include <math.h>
int main()
{
int x = 0;
int y = 0;
scanf("%d %d", &x, &y);
int ret = pow(x, y);
printf("%lf", (double)ret);
return 0;
}
4.2.1总结
printf函数的参数一号没有与变量类型对齐:结果会出错,以0的数值的各种形式进行打印。
解决方法:
1、第一个参数与变量类型对齐
2、第二个参数通过强制类型转换,将变量转为适配第一个参数的类型