用弦截法求方程f(x)=x^3-5x^2+16x-80=0的根 25
#include<stdio.h>#include<math.h>floatf(floatx){floaty;y=((x-5.0)*x+16.0)*x-80.0;retu...
#include<stdio.h>
#include<math.h>
float f(float x)
{
float y;
y=((x-5.0)*x+16.0)*x-80.0;
return(y);
}
float xpoint(float x1,float x2)
{
float y;
y=(x1*f(x2)-x2*f(x1))/(f(x2)-f(x1));
return(y);
}
float root(float x1,float x2)
{
float x,y,y1;
y1=f(x1);
do
{
x=xpoint(x1,x2);
y=f(x);
if(y*y1>0)
{
y1=y; <---/*书上有这句,但我想了一下,下次循环应该求出一个新的y
x1=x; 值,所以请教一下,这句有用么?可省么?*/
}
else
x2=x;
}
while(fabs(y)>=0.0001);
return(x);
}
void main()
{
float x1,x2,f1,f2,x;
do
{
printf("input x1,x2:\n");
scanf("%f,%f",&x1,&x2);
f1=f(x1);
f2=f(x2);
}
while(f1*f2>=0);
x=root(x1,x2);
printf("A root of equation is%8.4f\n",x);
}
问题在题里面,请高手帮忙讲讲,我试了一下,能运行,就是不知道我的想法对不,谢谢!!
555........我是真心求教谢谢。。。 展开
#include<math.h>
float f(float x)
{
float y;
y=((x-5.0)*x+16.0)*x-80.0;
return(y);
}
float xpoint(float x1,float x2)
{
float y;
y=(x1*f(x2)-x2*f(x1))/(f(x2)-f(x1));
return(y);
}
float root(float x1,float x2)
{
float x,y,y1;
y1=f(x1);
do
{
x=xpoint(x1,x2);
y=f(x);
if(y*y1>0)
{
y1=y; <---/*书上有这句,但我想了一下,下次循环应该求出一个新的y
x1=x; 值,所以请教一下,这句有用么?可省么?*/
}
else
x2=x;
}
while(fabs(y)>=0.0001);
return(x);
}
void main()
{
float x1,x2,f1,f2,x;
do
{
printf("input x1,x2:\n");
scanf("%f,%f",&x1,&x2);
f1=f(x1);
f2=f(x2);
}
while(f1*f2>=0);
x=root(x1,x2);
printf("A root of equation is%8.4f\n",x);
}
问题在题里面,请高手帮忙讲讲,我试了一下,能运行,就是不知道我的想法对不,谢谢!!
555........我是真心求教谢谢。。。 展开
4个回答
展开全部
s
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询