用弦截法求一元三次方程的根

网上好多人这样写,经过测试,当第二个数大于6时,程序就出错了,我纠结了一下午,原来是float的问题:把float改为double就好了,第二个代码可以解释为什么.

#include<math.h>
#include<stdio.h>

float f(double x)
{
	return ((x-5)*x+16)*x-80;
}

float xpoint(float x1,float x2)
{
	return (x1*f(x2)-x2*f(x1))/(f(x2)-f(x1));
}

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;
			   x1=x;
		   }
		else
			x2=x;
		printf("%f\n",fabs(y));
	}while(fabs(y)>0.000001);

    return x;
}

void main()
{
  float x,x1,x2,y1,y2;
  do
  {
    printf("INPUT X1,X2:\n");
    scanf("%f%f",&x1,&x2);
     y1=f(x1);
    y2=f(x2);
	
  }while(y1*y2>0);
  x=root(x1,x2);
  printf("A ROOT IS:%f\n:",x);

}

 

#include<stdio.h>
int main()
{
	float i;
	i=0.0000000000000000000000000000000000001;
	printf("%f\n",1/3);              
	printf("%e\n",1/3);              
	printf("%f\n",1.5/3);             
	printf("%e\n",1.5/3);
	printf("%f\n",0.0000001);        //打印0.000000
	printf("%e\n",i);
	printf("%f\n",0.00000001);
	return 0;
}



 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

嵌入式小侠

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值