⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 sqrt.c

📁 unix v7是最后一个广泛发布的研究型UNIX版本
💻 C
字号:
/*	sqrt returns the square root of its floating	point argument. Newton's method.	calls frexp*/#include <errno.h>int errno;double frexp();doublesqrt(arg)double arg;{	double x, temp;	int exp;	int i;	if(arg <= 0.) {		if(arg < 0.)			errno = EDOM;		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 + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -