十万火急!c语言编程中出现的问题,请大侠帮忙!
后面注释了程序在编译时的提示doublef11(doublex,doublee,doublez){if((e<=0.002)&&(e>=0.0))f11=16.7*((2...
后面注释了程序在编译时的提示
double f11(double x,double e,double z)
{
if((e<=0.002)&&(e>=0.0))
f11=16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002)); ( 错误1:非法定义浮点数 )
else if((e<=0.0033)&&(e>=0.002))
f11=16.7*(1.0-0.15*((e-z*x)-0.002)/0.0013);( 错误2:非法定义浮点数 )
}(警告1:函数要有一个返回值,参数X,Z,e从未使用过)
double f12(double x,double z,double e)
{
f12=16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));( 错误3:非法定义浮点数 )
} (警告2:函数要有一个返回值,参数X,Z,e从未使用过)
#include "math.h"
double fftsf(x)
double x;
{ double y;
y=f11(x); (错误4:调用f11参数太少)
return(y);
}
double fftsf(x)
{ double y; (错误5:重复定义fftsf)
y=f(12);
return(y);
} (警告3:参数X从未使用过)
#include "stdio.h"
#include "9ffts.c"
main()
{
double a,eps,e,k,fy1,fy2,es1,es2,h,ey1,ey2;
double z,xx1,xx2,gh1,gh2,t11,b;
double a12,b12,t12,h0,yn;
k=0.50;
h0=315.0;
while(e<=0.0033)
z=e/(k*h0);
xx1=300.00;
xx2=-300.00;
gh1=0.002/z;
a=0.0; b=k*h0-gh1; eps=0.000001;
t11=ffts(a,b,eps,f11);
a=k*h0-gh1; b=k*h0; eps=0.000001;
t12=ffts(a,b,eps,f12);
yn=t11+t12;
while ((xx2<=yn)&&(yn<=xx1))
z=e/(k*h0);
scanf("%f,%f,%f",&e,&k,&z);
if(yn<xx2)
do {k=k+0.0001;}
while (xx2<=yn);
if(yn>xx1)
do {k=k-0.0001;}
while (yn<=xx1);
printf("%f\n","%f\n",&z,&yn);
return 0;
}
经过改正后只有一处警告和错误了 //#include "9ffts.c"是求函数积分里面的一个函数
double f11(double x,double e,double z)
{ if((e<=0.002)&&(e>=0.0))
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));
else if((e<=0.0033)&&(e>=0.002))
return 16.7*(1.0-0.15*((e-z*x)-0.002)/0.0013);
} (警告:函数要返回一个值)
double f12(double x,double z,double e)
{
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));
}
#include "math.h"
double fftsf(x,e,z)
double x;
{ double y;
y=f11(x,e,z);
return(y);
}
double fftsf(x,e,z)
{ double y; (错误:重复定义函数fftsf)
y=f12(x,e,z);
return(y);
}
请大家帮忙看一下,该怎么改啊。 展开
double f11(double x,double e,double z)
{
if((e<=0.002)&&(e>=0.0))
f11=16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002)); ( 错误1:非法定义浮点数 )
else if((e<=0.0033)&&(e>=0.002))
f11=16.7*(1.0-0.15*((e-z*x)-0.002)/0.0013);( 错误2:非法定义浮点数 )
}(警告1:函数要有一个返回值,参数X,Z,e从未使用过)
double f12(double x,double z,double e)
{
f12=16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));( 错误3:非法定义浮点数 )
} (警告2:函数要有一个返回值,参数X,Z,e从未使用过)
#include "math.h"
double fftsf(x)
double x;
{ double y;
y=f11(x); (错误4:调用f11参数太少)
return(y);
}
double fftsf(x)
{ double y; (错误5:重复定义fftsf)
y=f(12);
return(y);
} (警告3:参数X从未使用过)
#include "stdio.h"
#include "9ffts.c"
main()
{
double a,eps,e,k,fy1,fy2,es1,es2,h,ey1,ey2;
double z,xx1,xx2,gh1,gh2,t11,b;
double a12,b12,t12,h0,yn;
k=0.50;
h0=315.0;
while(e<=0.0033)
z=e/(k*h0);
xx1=300.00;
xx2=-300.00;
gh1=0.002/z;
a=0.0; b=k*h0-gh1; eps=0.000001;
t11=ffts(a,b,eps,f11);
a=k*h0-gh1; b=k*h0; eps=0.000001;
t12=ffts(a,b,eps,f12);
yn=t11+t12;
while ((xx2<=yn)&&(yn<=xx1))
z=e/(k*h0);
scanf("%f,%f,%f",&e,&k,&z);
if(yn<xx2)
do {k=k+0.0001;}
while (xx2<=yn);
if(yn>xx1)
do {k=k-0.0001;}
while (yn<=xx1);
printf("%f\n","%f\n",&z,&yn);
return 0;
}
经过改正后只有一处警告和错误了 //#include "9ffts.c"是求函数积分里面的一个函数
double f11(double x,double e,double z)
{ if((e<=0.002)&&(e>=0.0))
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));
else if((e<=0.0033)&&(e>=0.002))
return 16.7*(1.0-0.15*((e-z*x)-0.002)/0.0013);
} (警告:函数要返回一个值)
double f12(double x,double z,double e)
{
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));
}
#include "math.h"
double fftsf(x,e,z)
double x;
{ double y;
y=f11(x,e,z);
return(y);
}
double fftsf(x,e,z)
{ double y; (错误:重复定义函数fftsf)
y=f12(x,e,z);
return(y);
}
请大家帮忙看一下,该怎么改啊。 展开
2个回答
展开全部
#include "math.h"
#include "stdio.h"
//下面这个是什么?
//#include "9ffts.c"
double f11(double x,double e,double z) //注意,函数f11有三个参数,而且没有设置默认值
{
if((e<=0.002)&&(e>=0.0))
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002)); //( 错误1:非法定义浮点数 ) 原来的f11是什么意思?改成了return!
else if((e<=0.0033)&&(e>=0.002))
return 16.7*(1.0-0.15*((e-z*x)-0.002)/0.0013);//( 错误2:非法定义浮点数 ) return!
}//(警告1:函数要有一个返回值,参数X,Z,e从未使用过)
double f12(double x,double z,double e) //注意,函数f12有三个参数,而且没有设置默认值
{
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));//( 错误3:非法定义浮点数 ) return!
}// (警告2:函数要有一个返回值,参数X,Z,e从未使用过)
double x;
{ double y;
y=f11(x); //(错误4:调用f11参数太少) f11有三个参数的?
return y;
}
double fftsf(double x)
{ double y;// (错误5:重复定义fftsf) 前面的声明被删除掉了
//想写什么?f12(x)么?别忘了有三个参数的!
//y=f(12);
return y;
} //(警告3:参数X从未使用过)
main()
{
double a,eps,e,k,fy1,fy2,es1,es2,h,ey1,ey2;
double z,xx1,xx2,gh1,gh2,t11,b;
double a12,b12,t12,h0,yn;
k=0.50;
h0=315.0;
while(e<=0.0033)
z=e/(k*h0);
xx1=300.00;
xx2=-300.00;
gh1=0.002/z;
a=0.0; b=k*h0-gh1; eps=0.000001;
t11=ffts(a,b,eps,f11);
a=k*h0-gh1; b=k*h0; eps=0.000001;
t12=ffts(a,b,eps,f12);
yn=t11+t12;
while ((xx2<=yn)&&(yn<=xx1))
z=e/(k*h0);
scanf("%f,%f,%f",&e,&k,&z);
if(yn<xx2)
do {k=k+0.0001;}
while (xx2<=yn);
if(yn>xx1)
do {k=k-0.0001;}
while (yn<=xx1);
printf("%f\n","%f\n",&z,&yn);
return 0;
}
代码的可读性太低了,估计一段时间之后你回头看自己写的东西都看不明白了。开始写东西还是规范一点的好。
#include "stdio.h"
//下面这个是什么?
//#include "9ffts.c"
double f11(double x,double e,double z) //注意,函数f11有三个参数,而且没有设置默认值
{
if((e<=0.002)&&(e>=0.0))
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002)); //( 错误1:非法定义浮点数 ) 原来的f11是什么意思?改成了return!
else if((e<=0.0033)&&(e>=0.002))
return 16.7*(1.0-0.15*((e-z*x)-0.002)/0.0013);//( 错误2:非法定义浮点数 ) return!
}//(警告1:函数要有一个返回值,参数X,Z,e从未使用过)
double f12(double x,double z,double e) //注意,函数f12有三个参数,而且没有设置默认值
{
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));//( 错误3:非法定义浮点数 ) return!
}// (警告2:函数要有一个返回值,参数X,Z,e从未使用过)
double x;
{ double y;
y=f11(x); //(错误4:调用f11参数太少) f11有三个参数的?
return y;
}
double fftsf(double x)
{ double y;// (错误5:重复定义fftsf) 前面的声明被删除掉了
//想写什么?f12(x)么?别忘了有三个参数的!
//y=f(12);
return y;
} //(警告3:参数X从未使用过)
main()
{
double a,eps,e,k,fy1,fy2,es1,es2,h,ey1,ey2;
double z,xx1,xx2,gh1,gh2,t11,b;
double a12,b12,t12,h0,yn;
k=0.50;
h0=315.0;
while(e<=0.0033)
z=e/(k*h0);
xx1=300.00;
xx2=-300.00;
gh1=0.002/z;
a=0.0; b=k*h0-gh1; eps=0.000001;
t11=ffts(a,b,eps,f11);
a=k*h0-gh1; b=k*h0; eps=0.000001;
t12=ffts(a,b,eps,f12);
yn=t11+t12;
while ((xx2<=yn)&&(yn<=xx1))
z=e/(k*h0);
scanf("%f,%f,%f",&e,&k,&z);
if(yn<xx2)
do {k=k+0.0001;}
while (xx2<=yn);
if(yn>xx1)
do {k=k-0.0001;}
while (yn<=xx1);
printf("%f\n","%f\n",&z,&yn);
return 0;
}
代码的可读性太低了,估计一段时间之后你回头看自己写的东西都看不明白了。开始写东西还是规范一点的好。
展开全部
double f11(double x,double e,double z)
{
if((e<=0.002)&&(e>=0.0))
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002)); (改动)
else if((e<=0.0033)&&(e>=0.002))
return 16.7*(1.0-0.15*((e-z*x)-0.002)/0.0013);( 改动 )
}(警告1:函数要有一个返回值,参数X,Z,e从未使用过)
double f12(double x,double z,double e)
{
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));( 改动)
} (警告2:函数要有一个返回值,参数X,Z,e从未使用过)
调用的时候有3个参数就传3个参数阿
{
if((e<=0.002)&&(e>=0.0))
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002)); (改动)
else if((e<=0.0033)&&(e>=0.002))
return 16.7*(1.0-0.15*((e-z*x)-0.002)/0.0013);( 改动 )
}(警告1:函数要有一个返回值,参数X,Z,e从未使用过)
double f12(double x,double z,double e)
{
return 16.7*((2.0*(e-z*x))/0.002-((e-z*x)/0.002)*((e-z*x)/0.002));( 改动)
} (警告2:函数要有一个返回值,参数X,Z,e从未使用过)
调用的时候有3个参数就传3个参数阿
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询