包含頭文件 math.h
創(chuàng)新互聯(lián)專注于海棠網(wǎng)站建設(shè)服務(wù)及定制,我們擁有豐富的企業(yè)做網(wǎng)站經(jīng)驗。 熱誠為您提供海棠營銷型網(wǎng)站建設(shè),海棠網(wǎng)站制作、海棠網(wǎng)頁設(shè)計、海棠網(wǎng)站官網(wǎng)定制、微信平臺小程序開發(fā)服務(wù),打造海棠網(wǎng)絡(luò)公司原創(chuàng)品牌,更為您提供海棠網(wǎng)站排名全網(wǎng)營銷落地服務(wù)。
反3角函數(shù)有 acos(double),asin(double),atan(double),atan(double,double),
返回值 double 型,弧度值。轉(zhuǎn)角度要 *180.0/3.1416
例如:
#include stdio.h
#includestdlib.h
#includemath.h
int main()
{
double x=0.5;
printf("acos=%.2lf degrees\n",acos(x) * 180.0/3.1416);
printf("asin=%.2lf degrees\n",asin(x) * 180.0/3.1416);
printf("atan=%.2lf degrees\n",atan(x) * 180.0/3.1416);
printf("atan2=%.2lf degrees\n",atan2(1.0,2.0) * 180.0/3.1416);
return 0;
}
#include?"math.h"
double?fn[1000]?=?{1};
double?f(int?n)?{
int?i;
if?(fn[n])?return?fn[n];
for?(i?=?1;?i?=?n;?i++)?{
if?(fn[n-i])?{
int?t?=?n-i+1;
while?(t?=?n)?{
fn[t]?=?fn[t-1]*?t;
t++;
}
break;
}
}
return?fn[n];
}
double?C(double?x,?int?n)?{
int?t?=?2*n;
return?f(t)*pow(x,t+1)/(pow(2,?t)?*?f(n)?*?f(n)?*(t+1));
}
double?asin0(double?x)
{
double?res?=?0,?t;
int?i?=?0;
do?{
t?=?C(x,?i++);
res?+=?t;
}while?(t??1e-7);
return?res;
}
int?main()?{
printf("%f",?asin0(0.5));
return?0;
}
C語言中之?dāng)?shù)學(xué)函數(shù)
C語言提供了以下的數(shù)學(xué)函數(shù),要使用這些函數(shù)時,在程序文件頭必須加入:
#include
math.h
編譯時,必須加上參數(shù)「-lm」(表示連結(jié)至數(shù)學(xué)函式庫),例如「gcc
-lm
test.c」。
函數(shù)之自變量與傳回之值型別見自變量或函數(shù)前之型別宣告。
函數(shù)已經(jīng)在「math.h」或其它標(biāo)頭檔宣告過了,因此在使用時不必再加型別宣告,例如「y=sin(x);」,不用寫成「y=double
sin(double
x);」。
函數(shù)說明
double
sin(double
x)
x
的正弦函數(shù)值
double
cos(double
x)
x
的余弦函數(shù)值
double
tan(double
x)
x
的正切函數(shù)值
double
asin(double
x)
x
的反正弦函數(shù)值
sin-1x,x的值在
[-1,1]
之間,傳回的值在
[-p/2,p/2]
之間
double
acos(double
x)
x
的反余弦函數(shù)值cos-1x,x的值在
[-1,1]
之間,傳回的值在
[-p/2,p/2]
之間
double
atan(double
x)
x
的反正切函數(shù)值tan-1x,傳回的值在
[-p/2,p/2]
之間
double
atan2(double
y,
double
x)
y/x
的反正切函數(shù)值tan-1(y/x),傳回的值在
[-p,
p]
之間
double
sinh(double
x)
x
的雙曲正弦函數(shù)值
double
cosh(double
x)
x
的雙曲余弦函數(shù)值
double
tanh(double
x)
x
的雙曲正切函數(shù)值
double
exp(double
x)
x
的指數(shù)函數(shù)
ex
double
log(double
x)
x
的自然對數(shù)
ln(x),x
double
log10(double
x)
x
底數(shù)為
10
的對數(shù),log10x,x
double
pow(double
x,
double
y)
x
的
y
次方
xy
double
sqrt(double
x)
x
的根號值
√x
double
ceil(double
x)
不小于
x
的最小整數(shù)(但其型別為
double)
double
floor(double
x)
不大于
x
的最大整數(shù)(但其型別為
double)
int
abs(int
x)
整數(shù)
x
的絕對值
|x|
long
labs(long
x)
長整數(shù)
x
的絕對值
|x|
double
fabs(double
x)
實數(shù)
x
的絕對值
|x|
sacnf("%s",a);這個語句根本沒的用。就算輸入到a,也只會被當(dāng)成字符串來處理。
printf("%f",j);這個語句不知道是不是你寫錯了,j前面沒逗號。
你想想反余切的公式就可以編程 出來了,這個東西最好要自己實踐,別人幫你只是指導(dǎo)你,對你編程沒有實際的好處。
如果math.h庫中沒有的話,提供你一條思路,在數(shù)學(xué)手冊上去查一下 arctan的級數(shù)展開式。我多年前曾用匯編編制過tan函數(shù),就用此方法。
搜到一些公式,不知你以后是否會用,都寫上了。
arctan x = x - x^3/3 + x^5/5 - ... (x≤1)
ex = 1+x+x2/2!+x3/3!+...+xn/n!+...
ln(1+x)= x-x2/3+x3/3-...(-1)k-1*xk/k+... (|x|1)
sin x = x-x3/3!+x5/5!-...(-1)k-1*x2k-1/(2k-1)!+... (-∞x∞)
cos x = 1-x2/2!+x4/4!-...(-1)k*x2k/(2k)!+... (-∞x∞)
arcsin x = x + 1/2*x3/3 + 1*3/(2*4)*x5/5 + ... (|x|1)
arccos x = π - ( x + 1/2*x3/3 + 1*3/(2*4)*x5/5 + ... ) (|x|1)
sinh x = x+x3/3!+x5/5!+...(-1)k-1*x2k-1/(2k-1)!+... (-∞x∞)
cosh x = 1+x2/2!+x4/4!+...(-1)k*x2k/(2k)!+... (-∞x∞)
arcsinh x = x - 1/2*x3/3 + 1*3/(2*4)*x5/5 - ... (|x|1)
arctanh x = x + x^3/3 + x^5/5 + ... (|x|1)
計算反正切函數(shù)(使用歐拉變換公式,精度很高),反正切函數(shù)的級數(shù)展開公式:
f(x) = x - x^3/3 + x^5/5 +...+ (-1)^k * x^(2k+1)/(2k + 1)+...
當(dāng)|x| 1時,級數(shù)絕對值發(fā)散,無法直接使用歐拉公式計算。因此可以通過下面的公式
進(jìn)行等價轉(zhuǎn)換之后再進(jìn)行計算。
等價轉(zhuǎn)換公式:
a) ATan(1/x) = Pi/2 - ATan(x)
b) ATan(-x) = - ATan(x)
特殊情況
0 = ArcTan(0)
Pi/2 = ArcTan(無窮大)
//
// 歐拉公式
//
// sum是和,term是通項值,jterm初始為1,以后按1遞增。wrksp是工作單元,視jterm的
// 最大值而定。
//
void eulsum(int nterm,double *sum,double term,int jterm,double wrksp[])
{
double tmp,dum;
if(jterm == 1)
{
nterm = 1;
wrksp[1] = term;
*sum = 0.5 * term;
}
else
{
tmp = wrksp[1];
wrksp[1] = term;
for(int j=1; j = nterm; j++)
{
dum = wrksp[j+1];
wrksp[j+1] = 0.5 * (wrksp[j] + tmp);
tmp = dum;
}
if(fabs(wrksp[nterm + 1]) = fabs(wrksp[nterm]))
{
*sum = *sum + 0.5 * wrksp[nterm + 1];
nterm = nterm + 1;
}
else
{
*sum = *sum + wrksp[nterm + 1];
}
}
}
級數(shù)計算就不用我給代碼了吧。