欢迎您 本站地址:  

C 库函数 - exp()

C 标准库 - <math.h> C 标准库 - <math.h>

描述

C 库函数 double exp(double x) 返回 ex 次幂的值。

exp() 是 C 标准库 <math.h> 中的一个函数,用于计算 e 的 x 次幂,其中 e 是自然对数的底数(约为 2.71828)。这是一个常用的数学函数,广泛应用于科学计算、金融和工程等领域。

声明

下面是 exp() 函数的声明。

#include <math.h>

double exp(double x);
float expf(float x);
long double expl(long double x);

参数

返回值

该函数返回 e 的 x 次幂。

实例

下面的实例演示了 exp() 函数的用法。

实例

#include <stdio.h>
#include <math.h>

int main ()
{
   double x = 0;
 
   printf("e 的 %lf 次幂是 %lf\n", x, exp(x));
   printf("e 的 %lf 次幂是 %lf\n", x+1, exp(x+1));
   printf("e 的 %lf 次幂是 %lf\n", x+2, exp(x+2));
   
   return(0);
}

让我们编译并运行上面的程序,这将产生以下结果:

e 的 0.000000 次幂是 1.000000
e 的 1.000000 次幂是 2.718282
e 的 2.000000 次幂是 7.389056

计算多个值的指数

以下示例展示了如何计算多个值的指数:

实例

#include <stdio.h>
#include <math.h>

int main() {
    double values[] = {0, 0.5, 1, 1.5, 2};
    int num_values = sizeof(values) / sizeof(values[0]);

    for (int i = 0; i < num_values; i++) {
        double x = values[i];
        double result = exp(x);
        printf("exp(%f) = %f\n", x, result);
    }

    return 0;
}

让我们编译并运行上面的程序,这将产生以下结果:

exp(0.000000) = 1.000000
exp(0.500000) = 1.648721
exp(1.000000) = 2.718282
exp(1.500000) = 4.481689
exp(2.000000) = 7.389056

代码解析

错误处理

exp() 函数在输入值过大时可能会导致上溢出。在这种情况下,函数返回正无穷大,并且 errno 设置为 ERANGE。可以使用 errno 来检查是否发生了上溢出错误。

以下示例展示了如何处理上溢出错误:

实例

#include <stdio.h>
#include <math.h>
#include <errno.h>

int main() {
    double x = 1000.0;
    errno = 0;  // 重置 errno
    double result = exp(x);

    if (errno == ERANGE) {
        printf("Overflow error: exp(%f) result is out of range.\n", x);
    } else {
        printf("exp(%f) = %f\n", x, result);
    }

    return 0;
}

让我们编译并运行上面的程序,这将产生以下结果:

exp(1000.000000) = inf

代码解析

总结

exp() 函数用于计算 e 的 x 次幂,是处理指数运算的重要工具。在使用时,应注意处理可能的上溢出错误。通过合理使用 exp() 函数,可以在数学计算、物理模拟和工程应用中得到准确的结果。

C 标准库 - <math.h> C 标准库 - <math.h>

小库提示

扫描下方二维码,访问手机版。