sqrt.c

来自「这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易」· C语言 代码 · 共 53 行

C
53
字号
/*	sqrt returns the square root of its floating	point argument. Newton's method.	calls frexp*/#include <u.h>#include <libc.h>doublesqrt(double arg){	double x, temp;	int exp, i;	if(arg <= 0) {		if(arg < 0)			return 0.;		return 0;	}	x = frexp(arg, &exp);	while(x < 0.5) {		x *= 2;		exp--;	}	/*	 * NOTE	 * this wont work on 1's comp	 */	if(exp & 1) {		x *= 2;		exp--;	}	temp = 0.5 * (1.0+x);	while(exp > 60) {		temp *= (1L<<30);		exp -= 60;	}	while(exp < -60) {		temp /= (1L<<30);		exp += 60;	}	if(exp >= 0)		temp *= 1L << (exp/2);	else		temp /= 1L << (-exp/2);	for(i=0; i<=4; i++)		temp = 0.5*(temp + arg/temp);	return temp;}

⌨️ 快捷键说明

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