天天看點

C程式語言中數學函數

C語言中之數學函數

   C語言提供了以下的數學函數,要使用這些函數時,在程式檔案頭必須加入:

   #include <math.h>

  編譯時,必須加上參數「-lm」(表示連結至數學函式庫),例如「gcc -lm test.c」。

  函數之自變量與傳回之值型别見自變量或函數前之型别宣告。

  函數已經在「math.h」或其它标頭檔宣告過了,是以在使用時不必再加型别宣告,例如「y=sin(x);」,不用寫成「y=double sin(double x);」。

  函數說明

   double sin(double x)

   x 的正弦函數值

   double cos(double x)

   x 的餘弦函數值

   double tan(double x)

   x 的正切函數值

   double asin(double x)

   x 的反正弦函數值 sin-1x,x的值在 [-1,1] 之間,傳回的值在 [-p/2,p/2] 之間

   double acos(double x)

   x 的反餘弦函數值cos-1x,x的值在 [-1,1] 之間,傳回的值在 [-p/2,p/2] 之間

   double atan(double x)

   x 的反正切函數值tan-1x,傳回的值在 [-p/2,p/2] 之間

   double atan2(double y, double x)

   y/x 的反正切函數值tan-1(y/x),傳回的值在 [-p, p] 之間

   double sinh(double x)

   x 的雙曲正弦函數值

   double cosh(double x)

   x 的雙曲餘弦函數值

   double tanh(double x)

   x 的雙曲正切函數值

   double exp(double x)

   x 的指數函數 ex

   double log(double x)

   x 的自然對數 ln(x),x > 0

   double log10(double x)

   x 底數為 10 的對數,log10x,x > 0

   double pow(double x, double y)

   x 的 y 次方 xy

   double sqrt(double x)

   x 的根号值 √x

   double ceil(double x)

  不小于 x 的最小整數(但其型别為 double)

   double floor(double x)

  不大于 x 的最大整數(但其型别為 double)

   int abs(int x)

  整數 x 的絕對值 |x|

   long labs(long x)

  長整數 x 的絕對值 |x|

   double fabs(double x)

  實數 x 的絕對值 |x|

   double ldexp(double x, int n)

   x?2n

   double fmod(double x, double y)

   x/y 的浮點數餘數,符号與 x 相同

函數名: atof

功 能: 把字元串轉換成浮點數

用 法: double atof(const char *nptr);

程式例:

#include <stdlib.h>

#include <stdio.h>

int main(void)

{

float f;

char *str = "12345.67";

f = atof(str);

printf("string = %s float = %f/n", str, f);

return 0;

}

函數名: atoi

功 能: 把字元串轉換成整型數

用 法: int atoi(const char *nptr);

程式例:

#include <stdlib.h>

#include <stdio.h>

int main(void)

{

int n;

char *str = "12345.67";

n = atoi(str);

printf("string = %s integer = %d/n", str, n);

return 0;

}

函數名: atol

功 能: 把字元串轉換成長整型數

用 法: long atol(const char *nptr);

程式例:

#include <stdlib.h>

#include <stdio.h>

int main(void)

{

long l;

char *str = "98765432";

l = atol(lstr);

printf("string = %s integer = %ld/n", str, l);

return(0);

}

繼續閱讀