C語言sin()用來計算參數x 的正玄值,然后將結果返回。返回-1 至1 之間的計算結果。
公司主營業(yè)務:成都網站設計、網站制作、移動網站開發(fā)等業(yè)務。幫助企業(yè)客戶真正實現(xiàn)互聯(lián)網宣傳,提高企業(yè)的競爭能力。成都創(chuàng)新互聯(lián)是一支青春激揚、勤奮敬業(yè)、活力青春激揚、勤奮敬業(yè)、活力澎湃、和諧高效的團隊。公司秉承以“開放、自由、嚴謹、自律”為核心的企業(yè)文化,感謝他們對我們的高要求,感謝他們從不同領域給我們帶來的挑戰(zhàn),讓我們激情的團隊有機會用頭腦與智慧不斷的給客戶帶來驚喜。成都創(chuàng)新互聯(lián)推出漢川免費做網站回饋大家。
例子:
#include math.h
main(){
double answer = sin(0.5);
printf("sin(0.5) = %f\n", answer);
}
執(zhí)行
sin(0.5) = 0.479426
C語言sin():
sin()原型:double sin(double x)
sin()角度與弧度:
π=180°
1°=π/180
1(rad)=180/π
角度轉弧度:用角度乘以π/180
弧度轉角度:用弧度乘以180/π,或者用rtod()函數
擴展資料:
與sin相似的acos函數
函數名: acos
功 能:計算并返回arccos(x)值、要求-1=X=1
函數與形參類型:
double acos(x)
double x;
程序例:
#include stdio.h
#include math.h int main(void)
{
double result;
double x = 0.5; result = acos(x);
printf("The arc cosine of %lf is %lf\n", x, result);
return 0;
}
參考資料:CSDN博客頻道-C語言中sin和cos的用法
C語言中有個 math.h 這個頭文件,使用數學公式時,引入這個頭文件即可
比如計算正弦值
double ds = sin(45); //直接調用
或者計算 a的b次冪
double dp = pow(a,b); //直接調用非常方便
/*泰勒公式求sin(x)*/
#includestdio.h
#include math.h
main()
{
double x,s1,e,s=0;
int n=1;
printf("輸入x和誤差范圍e:\n");
scanf("%lf %lf",x,e);/*誤差上限e要盡量取小,如取e為0.0000001。這里我們將e取為0.000001*/
s1=x;
do
{
s+=s1; /*s1為中間變量*/
s1=-s1*x*x/(n+1)/(n+2);
n+=2;
} while (fabs(s1)=e);/*fabs為對實數求絕對值的函數*/
printf("x=%lf\nsin(x)=%lf\n",x,s);
}
我用c-free試了一下,將getch()改成getchar就可以運行了,然后sin x 中的x指的是弧度,而不是角度,所以改了之后就可以運行了,結果是對的。不過我也明白為什么x的指比較大的時候就不能得到準確的答案
首先:程序應該這樣改!
#include
#include
main()
{
double
n;
double
b,c;
scanf("%lf",n);
b=sin(n);
c=cos(n);
printf("%.2lf\n%.2lf",b,c);
return
0;
}
其次,這里的n是弧度值,你說的90度應該輸入的是pi/2,而不是90,如果希望輸入90的話,那就這樣改!
#include
#include
main()
{
int
s;
double
n,b,c;
scanf("%d",s);
n=3.1415926*(s/180.0);
b=sin(n);
c=cos(n);
printf("%.2lf\n%.2lf",b,c);
return
0;
}
首先 你定義了double類型 而scanf();中用的是%f。
float型對應用%f
double型對應用%lf
這是第一個錯誤,輸入的數值根本就沒讀進去。
不過這不是唯一的錯誤,等我繼續(xù)調試。
。。。
printf()處也用%lf
fabs(sum/s)改為fabs(sum-s)。畢竟是前后兩次的結果相減的差小于ε時滿足精度。
編譯通過,運行正確。
初學做到這樣不錯了,繼續(xù)加油!