前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C语言实例_math.h库函数功能及其用法详解

C语言实例_math.h库函数功能及其用法详解

作者头像
DS小龙哥
发布2024-01-03 10:31:31
6640
发布2024-01-03 10:31:31
举报

一、前言

数学在计算机编程中扮演着至关重要的角色,C语言的math.h头文件提供了一系列的函数和工具,用于数学计算和常用数学函数的实现。这些函数包括数值运算、三角函数、指数对数函数等,为开发人员提供了强大的数学处理能力。本文将对math.h头文件中的所有函数进行全面介绍,包括功能和使用方法,以帮助大家更好地理解和利用该头文件。

在 C 语言中,math.h 头文件提供了许多与数学运算相关的函数和宏。以下是该头文件中常用的函数和宏及其功能的详细介绍:

image-20230816115046273
image-20230816115046273

二、函数功能介绍

【1】基本数学运算函数

  • double sin(double x):计算正弦函数的值。
  • double cos(double x):计算余弦函数的值。
  • double tan(double x):计算正切函数的值。
  • double asin(double x):计算反正弦函数的值。
  • double acos(double x):计算反余弦函数的值。
  • double atan(double x):计算反正切函数的值。
  • double atan2(double y, double x):计算给定直角坐标系中点(x,y)的反正切函数值。
  • double sinh(double x):计算双曲正弦函数的值。
  • double cosh(double x):计算双曲余弦函数的值。
  • double tanh(double x):计算双曲正切函数的值。
  • double exp(double x):计算指数函数的值。
  • double log(double x):计算自然对数函数的值。
  • double log10(double x):计算以 10 为底的对数函数的值。
  • double pow(double x, double y):计算 x 的 y 次幂。
  • double sqrt(double x):计算平方根函数的值。
  • double ceil(double x):向上取整,返回不小于 x 的最小整数值。
  • double floor(double x):向下取整,返回不大于 x 的最大整数值。
  • double fabs(double x):计算绝对值函数的值。

【2】其他常用函数

  • double fmod(double x, double y):计算 x 除以 y 的余数。
  • double round(double x):四舍五入,返回最接近 x 的整数。
  • double trunc(double x):截断,返回 x 的整数部分。
  • double modf(double x, double* intpart):将 x 拆分为整数部分和小数部分,并将整数部分存储在 intpart 中。
  • double hypot(double x, double y):计算两个参数的平方和的平方根。
  • double ldexp(double x, int exp):计算 x 乘以 2 的指定次幂。
  • double frexp(double value, int* exp):将 value 分解为尾数和指数,并将指数存储在 exp 中。
  • int isnan(double x):检查 x 是否是非数值(NaN)。
  • int isinf(double x):检查 x 是否是无穷大。
  • int isfinite(double x):检查 x 是否是有限数。
  • double copysign(double x, double y):返回与 x 绝对值相同但符号与 y 相同的值。
  • double erf(double x):计算误差函数的值。
  • double erfc(double x):计算余误差函数的值。

【3】宏、常量和特殊值

除了上述函数,math.h 头文件还定义了一些宏、常量和特殊值,例如:

  • M_PIM_E 等代表数学常量。
  • 常量INFINITYNAN 等表示特殊数值的常量。
  • 特殊值HUGE_VALHUGE_VALFHUGE_VALL 等特殊数值。

这些函数和宏可以在 C 语言中进行各种数学运算和数值处理。

三、用法示例

【1】基本数学运算函数:

代码语言:javascript
复制
#include <stdio.h>
#include <math.h>

int main() {
    double x = 1.5;
    double y = 2.0;

    double result1 = sin(x);
    printf("sin(%.2f) = %.2f\n", x, result1);

    double result2 = pow(x, y);
    printf("%.2f^%.2f = %.2f\n", x, y, result2);

    int result3 = ceil(x);
    printf("ceil(%.2f) = %d\n", x, result3);

    return 0;
}

输出结果:

代码语言:javascript
复制
sin(1.50) = 0.99
1.50^2.00 = 2.25
ceil(1.50) = 2

【2】其他常用函数:

代码语言:javascript
复制
#include <stdio.h>
#include <math.h>

int main() {
    double x = 3.7;
    double intpart;
    double fractpart;

    fractpart = modf(x, &intpart);
    printf("x = %.2f, integer part = %.2f, fractional part = %.2f\n", x, intpart, fractpart);

    double distance = hypot(3.0, 4.0);
    printf("Distance from origin to point (3, 4) is %.2f\n", distance);

    double value = 1234.56;
    int exp;
    double mantissa = frexp(value, &exp);
    printf("Value = %.2f, mantissa = %.2f, exponent = %d\n", value, mantissa, exp);

    return 0;
}

输出结果:

代码语言:javascript
复制
x = 3.70, integer part = 3.00, fractional part = 0.70
Distance from origin to point (3, 4) is 5.00
Value = 1234.56, mantissa = 0.97, exponent = 11
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-01-02,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、前言
  • 二、函数功能介绍
    • 【1】基本数学运算函数
      • 【2】其他常用函数
        • 【3】宏、常量和特殊值
        • 三、用法示例
          • 【1】基本数学运算函数:
            • 【2】其他常用函数:
            相关产品与服务
            对象存储
            对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档