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

📄 sqrt.c

📁 这是一个同样来自贝尔实验室的和UNIX有着渊源的操作系统, 其简洁的设计和实现易于我们学习和理解
💻 C
字号:
/*	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 + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -