English | 简体中文 | 繁體中文 | Русский язык | Français | Español | Português | Deutsch | 日本語 | 한국어 | Italiano | بالعربية
Biblioteca estándar de C - <math.h>
C 库函数 double frexp(double x, int *exponent) 将浮点数 x 分解为尾数和指数。返回值是尾数,并将指数存入 exponent 中。所得的值是 x = mantissa * 2 ^ exponent。
以下是 frexp() 函数的声明。
double frexp(double x, int *exponent)
x -- 要被计算的浮点值。
exponent -- 指向一个对象的指针,该对象存储了指数的值。
该函数返回规范化小数。如果参数 x 不为零,则规范化小数是 x 的平方,且它的绝对值范围从 1/2(包含)到 1(不包含)。如果 x 为零,则规范化小数是零,且零存储在 exp 中。
以下示例演示了 frexp() 函数的使用。
#include <stdio.h> #include <math.h> int main () { double x = 2048, fraction; int e; fraction = frexp(x, &e); printf("x = %."2lf = %.2lf * 2^%d\n", x, fracción, e); return(0); }
Compilamos y ejecutamos el programa anterior, lo que produce el siguiente resultado:
x = 2048.00 = 0.50 * 2^12