x类型必须是double


参考代码:


#include <iostream>

#include <iomanip>

using namespace std;

double fact(double), mypow(double, double);

int main()

{

double j, x, i, n, sum(0);

cin >> x >> n;

for(i=1.0; i<=n; i++)

{

sum += mypow(-1.0, i-1)*mypow(x, i)/fact(i);

}

cout <<  fixed << setprecision(4) << sum;

}

double fact(double n)//求阶乘 

{

int m;

double  k(1.0);

for(m=1; m<=n; m++)

{

k = k*m;

}

return k;

}

double mypow(double x, double n)//求x的n次幂 

{

int p;

double q(1.0);

for(p=1; p<=n; p++)

{

q *= x;

}

return q;

}






点赞(1)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 2 条评论

amwwfnfhv 5年前 回复TA
我知道那错了有一个返回没写double
amwwfnfhv 5年前 回复TA
#include<iostream>
#include<math.h>
#include <iomanip>
using namespace std;

double mypow(double x,int  n)
{
	double low;
	low=pow(x,n);
return low;
}

double fact(int n)
{
int s=1;
for(int i=1;i<n+1;i++)
s*=i;
return s;
}

int main()
{
double x,n,sum=0,t,l;
cin>>x>>n;
for(int  i=1;i<n+1;i++)
{
t=mypow(x,i);
l=fact(i);
if(i%2!=0)
 sum+=(t/l);
else
 sum-=(t/l);
}
cout<<setiosflags(ios::fixed)<<setprecision(4)<<sum<<endl;
return 0;
}

我這個寫只對了50%錯在那