erfen.txt

来自「提供常用数值计算的c++代码源程序。方便初学者进行练习!」· 文本 代码 · 共 37 行

TXT
37
字号
#include<iostream.h>
#include<math.h>
#define EPS 5e-6	//根容许的误差
#define DELTA 1e-6  //|f(x)|容许的误差
float Bisection( float a,float b,float (*f)(float) )
{
	float c,fc,fa=f(a),fb=f(b);
	int n=1;
	cout<<"二分次数\tc\tf(c)\n";
	while(1)
	{
		if( fa*fb>0 )
			return 0;
		c =(a+b)/2,fc =f(c);
		if( fabs(fc) < DELTA )
			break;
		else if (fa*fc<0)
		{
			b=c;
			fb=fc;
		}
		else
		{
			a=c;
			fa=fc;
		}
		if( b-a< EPS )
			break;
		cout<<'\t'<<n++<<'\t'<<c<<'\t'<<fc<<endl;
	}
	return c;
}

float f(float x)
{
	return x*x*x+x*x-3*x-3;		//求解的方程
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?