熟练掌握标准库函数的调用
- 常用数学函数:cos、sqrt、pow、exp、fabs、log、log10等
- 常用字符函数:isalnum、isalpha、isdigit、islower、toupper等
- 常用字符串函数:strcpy、strcmp、strcat、strlen等
一、常用的数学函数
exp
double exp( double arg );
说明:计算 e (欧拉数, 2.7182818 )的 arg 次幂
参数:arg 浮点值
返回值: 若不出现错误,则返回 arg 的底 e 指数(earg)。
若出现上溢所致的值域错误,则返回 +HUGE_VAL 、 +HUGE_VALF 或 +HUGE_VALL 。
若出现下溢所致的值域错误,则返回(舍入后的)正确结果。
错误处理:
报告 math_errhandling 中指定的错误。
若实现支持 IEEE 浮点算术( IEC 60559 ),则
若参数为 ±0 ,则返回 1
若参数为 -∞ ,则返回 +0
若参数为 +∞ ,则返回 +∞
若参数为 NaN ,则返回 NaN
注意:
对于 IEEE 兼容的 double 类型,若 709.8 < arg 则保证上溢,而若 arg < -708.4 则保证下溢。
log
float log ( float arg );
double log ( double arg );
long double log ( long double arg );
功能:计算 arg 的自然(底 e )对数。
参数:arg - 浮点或整数类型值
返回值:若不出现错误,则返回 arg 的自然(底 e )对数( ln(arg) 或loge(arg))。
若出现定义域错误,则返回实现定义值(支持的平台上为 NaN )。
若出现极点错误,则返回 -HUGE_VAL 、 -HUGE_VALF 或 -HUGE_VALL 。
错误处理:
报告 math_errhandling 中指定的错误。
若 arg 小于零则出现定义域错误。
若 arg 为零则可能出现极点错误。
若实现支持 IEEE 浮点算术( IEC 60559 ),则
若参数为 ±0 ,则返回 -∞ 并引发 FE_DIVBYZERO 。
若参数为 1 ,则返回 +0 。
若参数为负数,则返回 NaN 并引发 FE_INVALID 。
若参数为 +∞ ,则返回 +∞ 。
若参数为 NaN ,则返回 NaN 。
pow
float pow ( float base, float exp );
double pow ( double base, double exp );
long double pow ( long double base, long double exp );
算法
bsearch
#include <stdio.h>
#include <stdlib.h>
#include <limits.h>
struct data
{
int nr;
char const *value;
} dat[] = {{1,"Foo"},{2,"Bar"},{3,"hello"},{4,"world"}};
int a(void const *lhs, void const *rhs)
{
struct data const *const l = lhs;
struct data const *const r = rhs;
if (l->nr < r->nr) return -1;
else if (l->nr > r->nr) return 1;
else return 0;
// return (l->nr > r->nr) - (l->nr < r->nr); // 可行的简洁写法
// return l->nr - r->nr; // 错误的简洁写法(若给出 INT_MIN 就会失败)
}
int main(void)
{
struct data key = {.nr = 2};
struct data const *res = bsearch(&key,dat,sizeof dat/sizeof dat[0],sizeof dat[0],a);
if(res)
{
printf("No %d: %s \n",res->nr,res->value);
}
}