rtbis.c

来自「适合大型数值计算代码 现在网络上已经找不到了 购买需要20$」· C语言 代码 · 共 24 行

C
24
字号
#include <math.h>#define JMAX 40float rtbis(float (*func)(float), float x1, float x2, float xacc){	void nrerror(char error_text[]);	int j;	float dx,f,fmid,xmid,rtb;	f=(*func)(x1);	fmid=(*func)(x2);	if (f*fmid >= 0.0) nrerror("Root must be bracketed for bisection in rtbis");	rtb = f < 0.0 ? (dx=x2-x1,x1) : (dx=x1-x2,x2);	for (j=1;j<=JMAX;j++) {		fmid=(*func)(xmid=rtb+(dx *= 0.5));		if (fmid <= 0.0) rtb=xmid;		if (fabs(dx) < xacc || fmid == 0.0) return rtb;	}	nrerror("Too many bisections in rtbis");	return 0.0;}#undef JMAX

⌨️ 快捷键说明

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