C语言中计算x的n次方可以用库函数来实现。具体的代码如下:
我们提供的服务有:网站建设、做网站、微信公众号开发、网站优化、网站认证、堆龙德庆ssl等。为上1000家企事业单位解决了网站和推广的问题。提供周到的售前咨询和贴心的售后服务,是有科学管理、有技术的堆龙德庆网站制作公司
#include stdio.h
#include math.h
int main( ) {printf("%f",pow(x,n));return 0;}
C语言是一种结构化语言,它有着清晰的层次,可按照模块的方式对程序进行编写,且c语言的处理和表现能力都非常的强大,依靠非常全面的运算符和多样的数据类型,可以轻易完成各种数据结构的构建,通过指针类型更可对内存直接寻址以及对硬件进行直接操作。
扩展资料:
如果一个变量声明时在前面使用 * 号,表明这是个指针型变量。换句话说,该变量存储一个地址,而 *(此处特指单目运算符 * ,下同。C语言中另有 双目运算符 *) 则是取内容操作符,意思是取这个内存地址里存储的内容。指针是 C 语言区别于其他同时代高级语言的主要特征之一。
指针不仅可以是变量的地址,还可以是数组、数组元素、函数的地址。通过指针作为形式参数可以在函数的调用过程得到一个以上的返回值,不同于return(z)这样的仅能得到一个返回值。
参考资料来源:百度百科-C语言
double x,p; //定义两个双精度浮点数,x和p,同时分配存储单元
unsigned n; //定义一个无符号整数,n,同时分配存储单元
printf("Please input x:"); //输出"Please input x:",提示用户输入x的值
scanf("%lf",x); //输入一个浮点数,存在x所指向的存储单元
printf("Please input n:"); //输出"Please input n:",提示用户输入n的值
scanf("%d",n); //输入一个整数,存在n所指向的存储单元
p=1.0; //给p赋值为1.0
while(n--) p*=x; …………#//这是一个循环,在while后的括号内内容为真时,进入循环
语句为n--,就是先判断n的值是否为真,再执行n=n-1操作
若n不等于0,即语句为真
语句为真进入p*=x的语句循环
即p=p*x,其中,p的初始值为1.0,x是你输入的某浮点数
当n为零时退出循环,此时,一共执行了n次*x的操作,即x的n次方
p中存放的是x的n次方的结果
printf("%f",p); //输出p的值
在前面加上数学函数的头文件#include"math.h"
调用函数pow
定义double x,n;
然后将一个变量等于pow(x,n),那个变量就是X的N次方
#include "stdio.h"
void main()
{
int x,n;
long sum=1;
printf("请输入x:");
scanf("%d",x);
printf("请输入n:");
scanf("%d",n);
printf("%d的%d次方是",x,n);
for(int i=1;i=n;i++)
sum*=x;
printf("%d\n",sum);
}
double
pow(double
x,
double
y);
pow()用来计算以x
为底的
y
次方值,然后将结果返回
可能导致错误的情况:
如果底数
x
为负数并且指数
y
不是整数,将会导致
domain
error
错误。
如果底数
x
和指数
y
都是
0,可能会导致
domain
error
错误,也可能没有;这跟库的实现有关。
如果底数
x
是
0,指数
y
是负数,可能会导致
domain
error
或
pole
error
错误,也可能没有;这跟库的实现有关。
如果返回值
ret
太大或者太小,将会导致
range
error
错误。
错误代码:
如果发生
domain
error
错误,那么全局变量
errno
将被设置为
EDOM;
如果发生
pole
error
或
range
error
错误,那么全局变量
errno
将被设置为
ERANGE。
注意,使用
GCC
编译时请加入-lm。
#includestdio.h
#includemath.h
intmain()
{
printf("7
^
3
=
%f\n",pow(7.0,3.0));
printf("4.73
^
12
=
%f\n",pow(4.73,12.0));
printf("32.01
^
1.54
=
%f\n",pow(32.01,1.54));
return0;}
输出结果:
7
^
3
=
343.000000
4.73
^
12
=
125410439.217423
32.01
^
1.54
=
208.036691
区分x和n的类型,以及对结果的要求,可以有如下两种方式。
1 使用pow函数。
在C语言的标准头文件math.h中,有库函数pow,声明为
double pow(double x, double n);
其功能为计算x的n次方并返回结果。
所以可以用pow计算x的n次方。
该函数适用于以下几种情况:
a. 当n为浮点数类型时,必须使用pow。
b. 当x为浮点数或对结果值精度要求不高时,可以使用pow。
2 当x和n均为整型,且对结果要求绝对准确值,而不能是近似值时,可以自行编写整型乘方函数。
如
int pow_int(int x, int y)
{
int r = 1;
while(y--) r*=x;
return r;
}
其原理为,将x自乘y次,并将结果累计到r上,最终返回。
需要注意的是,使用该种方法时虽然可以得到准确值,但由于int可以表示的范围比double小很多,所以出现溢出的概率要比pow函数更大。