C语言:用二分法求方程的根,求具体可用程序;用二分法求下面方程在(-10,10)之间的一个根.2x3 - 4x2 + 3x - 6 = 0输入:一个小于1的非负实数e,它的值表示所能允许的误差输出:一个实数,其值为求得的一个根,要求精确到小数点后8位.若该区间上没有根,则输出“No Solution”例如:输入:0输出:2.00000000提示:对于一个连续函数f(x),若f(a)*f(b)
C语言:用二分法求方程的根,求具体可用程序;
用二分法求下面方程在(-10,10)之间的一个根.
2x3 - 4x2 + 3x - 6 = 0
输入:一个小于1的非负实数e,它的值表示所能允许的误差
输出:
一个实数,其值为求得的一个根,要求精确到小数点后8位.
若该区间上没有根,则输出“No Solution”
例如:输入:0
输出:2.00000000
提示:
对于一个连续函数f(x),若f(a)*f(b)
提供以下代码.
Fedora10下gcc4.3.2编译通过,手动测试通过.
#include
#include
#define DEFAULT_UPPER (10)
#define DEFAULT_LOWER (-10)
#define DEFAULT_E (0.00000001)
#define _MID(x,y) ((x+y)/2)
#define _VALUE(x) (2*x*x*x-4*x*x+3*x-6)
double _e;
int getRoot(double lower,double upper,double *result);
main()
{
double root;
printf("Enter a deviation:");
scanf("%lf",& _e);
if(_e == 0.0)
_e = DEFAULT_E;
if(getRoot(DEFAULT_LOWER,DEFAULT_UPPER,&root))
printf("Root:%2.8lf\n",root);
else
printf("Root:No Solution.\n");
}
int getRoot(double lower,double upper,double *result)
{
*result = _MID(lower,upper);
if(upper - lower