当前位置: 首页 > news >正文

分享c语言中一些实用的函数2

目录

一.头文件

1.sqrt()函数

2.sin,cos,tan函数

附加:宏定义π

3.exp函数

4.fabs函数

5.fmax函数

6.floor函数

7.log函数

附加:求一个数是几为数(运用floor函数和log函数)

8.pow函数

二.头文件

1.abs函数

附加:


一.头文件<math.h>

1.sqrt()函数

sqrt() 函数是 C 标准库中的数学函数,用于计算一个数字的平方根

原型:
double sqrt(double x);

返回值:返回一个数的平方根,返回值是 double 类型,即使输入的数整数

代码示例:

#include <stdio.h>
#include <math.h>int main() {double num = 25.0;double result;// 计算 num 的平方根result = sqrt(num);// 打印结果printf(" %.2f的平方根是%.2f\n", num, result);return 0;
}

结果如图:

2.sin,cos,tan函数

分别计算sin(),cos(),tan()弧度对应的三角函数值。

原型:
double sin(double x);
double cos(double x);
double tan(double x);

返回值:sincostan 函数计算弧度对应的三角函数值

代码示例:

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <math.h>
#ifndef M_PI
#define M_PI 3.14159265358979323846
#endifint main() {float angle = 45.0f;float radians = angle * M_PI / 180.0f;  // 将角度转换为弧度,M_PI是πfloat sin_value = sinf(radians);float cos_value = cosf(radians);float tan_value = tanf(radians);printf("sin(%.2f度) = %.4f\n", angle, sin_value);printf("cos(%.2f度) = %.4f\n", angle, cos_value);printf("tan(%.2f度) = %.4f\n", angle, tan_value);return 0;
}

结果如图:

附加:宏定义π

M_PI 是一个在某些编译器实现中定义的宏,表示数学常数 π(pi),大约为 3.14159265358979323846。它通常在 <math.h> 头文件中定义,但这不是 C 标准库的一部分,因此并非所有编译器都提供这个宏。

如果没有这个宏,则自己定义

#ifndef M_PI
#define M_PI 3.14159265358979323846
#endif

可以从上面的代码示例看到vs2022中并没有提供这个宏,所以在vs2022还是得自己定义来使用.

3.exp函数

exp 是用于计算自然指数函数 e的x次方 的标准库函数,定义在 <math.h> 头文件中。

原型:

double exp(double x);

返回值类型exp 函数返回 double 类型的结果

代码示例:

#include <stdio.h>
#include <math.h>int main() {double x = 1.0;double result = exp(x);printf("exp(%.2f) = %.4f\n", x, result);return 0;
}

结果:

注意:如果传递的是其他数值类型,编译器会进行隐式类型转换。(自然是都转换为double型的)

4.fabs函数

fabs 函数是 C 标准库中的一个函数,用于计算浮点数的绝对值。它定义在 <math.h> 头文件中。

原型:

double fabs(double x);

返回值类型fabs 函数返回 double 类型的结果。

代码示例:

#include <stdio.h>
#include <math.h>int main() {double num = -10.5;double abs_value = fabs(num);printf("%.2f的绝对值为%.2f\n", num, abs_value);return 0;
}

结果如图:

5.fmax函数

fmax 函数是 C 标准库中的一个函数,用于返回两个浮点数中的最大值。它定义在 <math.h> 头文件中。

原型:double fmax(double x, double y);

x,y分别为两个要比较的数.

返回值类型fmax 函数返回 double 类型的结果。

#include <stdio.h>
#include <math.h>int main() {double num1 = 10.5;double num2 = 20.3;double max_value = fmax(num1, num2);printf(" %.2f 和 %.2f 之间最大的值为 %.2f\n", num1, num2, max_value);return 0;
}

结果如图:

6.floor函数

floor 是一个标准库函数,用于计算小于或等于给定数的最大整数。它是一个数学函数,通常在浮点运算中使用。

原型:double floor(double x);

返回值类型floor 函数返回 double 类型的结果。

代码示例:

#include <stdio.h>
#include <math.h>int main() {double num = 10.7;double floor_value = floor(num);printf("%.2f的floor值为%.2f\n", num, floor_value);num = -10.7;floor_value = floor(num);printf("%.2f的floor值为%.2f\n", num, floor_value);return 0;
}

结果如图:

7.log函数

log 函数是 C 标准库中的一个函数,用于计算自然对数(即以 e 为底的对数)。它定义在 <math.h> 头文件中。

原型:double log(double x);

返回值类型log 函数返回 double 类型的结果。

代码示例:

#include <stdio.h>
#include <math.h>int main() {double num = 10.0;double log_value = log(num);printf("%.2f的log值为%.4f\n", num, log_value);return 0;
}

结果如图:

当然我们也可以在log后面加上数字,如:log10(),log2()(也就是换底数,后面没加数字默认为e)

代码示例:

#define _CRT_SECURE_NO_WARNINGS 1
#include <stdio.h>
#include <math.h>int main() {double num = 10.0;double num2 = 2.0;double log_value = log10(num);double log_value2 = log2(num2);printf("%.2f的log10值为%.4f\n", num, log_value);printf("%.2f的log2值为%.4f\n", num2, log_value2);return 0;
}

结果如图:

注意:log 函数的参数必须大于 0,因为对数函数在 0 及负数上未定义。

附加:求一个数是几为数(运用floor函数和log函数)

//求一个数是几位数
#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<math.h>
int getdigit(int i) {if (i == 0) {return 1;}return floor(log10(i)) + 1;//floor函数和log()都是math.h头文件里的
}
int main() {int n = getdigit(100);printf("100是%d位数", n);return 0;
}

当然,你想求其他数把100改一下就好。
 

8.pow函数

pow 函数是 C 标准库中的一个函数,用于计算一个数的幂。它定义在 <math.h> 头文件中。

原型:double pow(double base, double exponent);

  • base:底数。
  • exponent:指数

返回值:为一个 double 类型的结果.

代码示例:

#include <stdio.h>
#include <math.h>int main() {double base = 2.0;double exponent = 3.0;double result = pow(base, exponent);printf("%.2f的%.2f次方为%.2f\n", base, exponent, result);base = 5.0;exponent = 0.0;result = pow(base, exponent);printf("%.2f的%.2f次方为%.2f\n", base, exponent, result);base = 2.0;exponent = -2.0;result = pow(base, exponent);printf("%.2f的%.2f次方为%.2f\n", base, exponent, result);return 0;
}

结果如图:

ps:

以上的函数在一般情况下也可以强制转换为int型,只不过可能在某些情况会精度丢失,看个人使用。

比如说求2的3次方,结果为8,这时我们就可以用int型

二.头文件<stdlib.h>

1.abs函数

abs 函数是 C 标准库中的一个函数,用于计算整数的绝对值。它定义在 <stdlib.h> 头文件中。

原型:int abs(int x);

返回值类型abs 函数返回 int 类型的结果。

#include <stdio.h>
#include <stdlib.h>int main() {int num1 = -10;int num2 = 10;int abs_value1 = abs(num1);int abs_value2 = abs(num2);printf("%d的绝对值为%d\n", num1, abs_value1);printf("%d的绝对值为%d\n", num2, abs_value2);return 0;
}

结果如图:

附加:

c语言标准库中的宏定义:

以下都属于头文件<limits.h>:

  • CHAR_BIT:一个 char 类型所占用的位数(通常是 8)。
  • SCHAR_MINsigned char 类型的最小值。
  • SCHAR_MAXsigned char 类型的最大值。
  • UCHAR_MAXunsigned char 类型的最大值。
  • CHAR_MINchar 类型的最小值(如果 char 是 signed 类型,与 SCHAR_MIN 相同;否则为 0)。
  • CHAR_MAXchar 类型的最大值(如果 char 是 signed 类型,与 SCHAR_MAX 相同;否则与 UCHAR_MAX 相同)。
  • MB_LEN_MAX:多字节字符中的最大字节数。
  • SHRT_MINshort 类型的最小值。
  • SHRT_MAXshort 类型的最大值。
  • USHRT_MAXunsigned short 类型的最大值。
  • INT_MINint 类型的最小值。
  • INT_MAXint 类型的最大值。(int型的用的比较多)
  • UINT_MAXunsigned int 类型的最大值。
  • LONG_MINlong 类型的最小值。
  • LONG_MAXlong 类型的最大值。
  • ULONG_MAXunsigned long 类型的最大值。
  • LLONG_MINlong long 类型的最小值(如果支持)。
  • LLONG_MAXlong long 类型的最大值(如果支持)。
  • ULLONG_MAXunsigned long long 类型的最大值(如果支持)。

扣1下次派大星还教你

感谢大家的阅读!一键三连

扣1下次派大星还教你

扣1下次派大星还教你

扣1下次派大星还教你

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Unity复制对象时让私有变量也被复制的简单方法
  • 预算管理一体化系统技术标准V2.0 — 第一章-概述
  • cdn 内容分发网络
  • Cesium 高德地图暗黑化
  • LangChain(八)构建多Agent的AI系统-实战!
  • JavaScript模块化
  • 数据结构基础详解(C语言):单链表_定义_初始化_插入_删除_查找_建立操作_纯c语言代码注释讲解
  • java使用责任链模式进行优化代码
  • 使用腾讯云域名解析实现网站重定向
  • 程序编译和链接
  • 032-GeoGebra中级篇-列表与集合(list and set)及常用操作大全
  • latex换行\left[和\right]编译报错-解决方案
  • JavaScript 打印 V 和倒 V 图案的程序(Program to print V and inverted-V pattern)
  • 【前端面试】七、算法-迭代器和生成器
  • 【Stable Diffusion】(基础篇九)—— 扩展
  • 【159天】尚学堂高琪Java300集视频精华笔记(128)
  • 【腾讯Bugly干货分享】从0到1打造直播 App
  • eclipse(luna)创建web工程
  • FastReport在线报表设计器工作原理
  • opencv python Meanshift 和 Camshift
  • windows下mongoDB的环境配置
  • 编写符合Python风格的对象
  • 创建一个Struts2项目maven 方式
  • 复杂数据处理
  • 聊聊directory traversal attack
  • 无服务器化是企业 IT 架构的未来吗?
  • 源码之下无秘密 ── 做最好的 Netty 源码分析教程
  • 白色的风信子
  • ​ 全球云科技基础设施:亚马逊云科技的海外服务器网络如何演进
  • ​Distil-Whisper:比Whisper快6倍,体积小50%的语音识别模型
  • ​软考-高级-系统架构设计师教程(清华第2版)【第1章-绪论-思维导图】​
  • #define,static,const,三种常量的区别
  • #微信小程序:微信小程序常见的配置传旨
  • #我与Java虚拟机的故事#连载17:我的Java技术水平有了一个本质的提升
  • (11)MSP430F5529 定时器B
  • (13):Silverlight 2 数据与通信之WebRequest
  • (Java岗)秋招打卡!一本学历拿下美团、阿里、快手、米哈游offer
  • (论文阅读26/100)Weakly-supervised learning with convolutional neural networks
  • (面试必看!)锁策略
  • (三)elasticsearch 源码之启动流程分析
  • (十八)三元表达式和列表解析
  • (数位dp) 算法竞赛入门到进阶 书本题集
  • (算法)前K大的和
  • (一)SvelteKit教程:hello world
  • (转)3D模板阴影原理
  • (转)关于多人操作数据的处理策略
  • **PyTorch月学习计划 - 第一周;第6-7天: 自动梯度(Autograd)**
  • .cfg\.dat\.mak(持续补充)
  • .DFS.
  • .MSSQLSERVER 导入导出 命令集--堪称经典,值得借鉴!
  • .NET 8 跨平台高性能边缘采集网关
  • .net core 管理用户机密
  • .NET6实现破解Modbus poll点表配置文件
  • .NET开源快速、强大、免费的电子表格组件
  • @JsonFormat与@DateTimeFormat注解的使用