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

本文介绍了一个使用float类型导致的精度问题,并通过将float替换为double解决了该问题。同时,提供了两个示例代码,帮助理解float与double的区别及如何避免精度误差。

网上好多人这样写,经过测试,当第二个数大于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;
}



 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

嵌入式小侠

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

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

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

打赏作者

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

抵扣说明:

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

余额充值