当前位置:首页 » 编程语言 » c语言求sinx值
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

c语言求sinx值

发布时间: 2023-05-14 03:50:23

Ⅰ 用c语言程序算sinX的值

#include
#include
/*计算n的阶乘*/
int factor(int n)
{
if(n==1)
return 1;
else
return factor(n-1)*n;
}
/*得到分子的值*/
double get_numerator(double x,int order)
{
return pow(x,order); //求x^order
}
/*得到分母的值*/
double get_denominator(int n)
{
return factor(n); //求n的阶乘
}
/*获得第n项的符号,即(-1)^n*/
int get_symbol(int n)
{
if(n%2 ==0) //n是偶数
return 1;
else
return -1;
}
int main()
{
int i;
double x;
double sin_x=0;
double tmp=0;
printf("please input the x:\n");
scanf("%lf",&x);
for(i=0;;i++)
{
tmp=sin_x; //暂时保存上一步得到的sin值
sin_x += get_numerator(x,2*i+1)/get_denominator(2*i+1)*get_symbol(i);
if(fabs(sin_x-tmp)<1e-6) //精度满足要求
break;
}
printf("sin(%lf)=%lf\n",x,sin_x);
return 0;
} /***********************************************************************
学好c语言,首先应该把语言的语法学好,这也是基础。尤其是注意指针部分,可以说这是c语言的精髓,也是c语言能够直接操作内存的犀利之处。
其次,应该多练代码,并且注意代码的可读性,规范性。
最好,能够亲身用c语言参加某个项目实践,毕竟实践出真知。
至于之后c++或者java的学习,要看自己的发展规划了。不过学好c语言,绝对对你今后学习其他语言有很大帮助。
*************************************************************************/

Ⅱ c语言计算sinx的值问题,运行无错但得不到想要的结果.求解

/*sin(x)的泰勒展开式
sin(x)=x-x**3/(3!)+x**5/(5!)+........
*/
#include
#include
#define
PI
3.1415926
void
main()
{
int
n=1,c=1,a,b=1;
long
double
x,d=0,sinx=0;//这里定义长双精度,long
float不是标准的数据类型
printf("请输入x的值:");
scanf("%lf",&x);//这里输入一定是%lf,输入一开始就不对
for(n=1,c=1,a=1;;a++)
{
d=pow(x,n)/c;
sinx+=b*d;
b*=-1;
n++;
c*=n;
n++;
c*=n;
if(d<1e-5)//可以写成1e-5,不需再调用函数
{
break;
}
}
printf("sinx的值为%f\n",sinx);
printf("运行的项数为%d\n",a);
printf("sin(x)的值为%lf\n",sin(x));//作测试对比,注意输入为弧度
}

Ⅲ c语言编程求sinx的近似值(泰勒展开)

您好,是这样的:泰勒展开是这个:sinx=x-x^3/3!+x^5/5!-..
下面给出算20项的程序。

#include"math.h"
#include"stdio.h"
void main()
{
double x=0,y=0,z=1,s=1,mynum=0;
int i=1 ,j=0, k=1;
scanf("x=%f",&x);

for(i=1;i<20;i++)

z=1;k=1;
for(j=1;j<=2*i-1;j++)
{
z=x*z;//算j次方
k=k*j;//算阶乘}
s=-j*pow(-1,i);//pow(a,b)是a的b次方
z=z*s/k;

mymun=mynum+z;
}
printf("sinx=x-x^3/3!+x^5/5!-..");
printf("sinx=%f",mynum);
getch();
}

Ⅳ c语言求泰勒公式sinx近似值

你的程序错误太多。直接给出按泰勒公式展开求sinx近似值的程序。

#include<stdio.h>
#include<math.h>
intmain()
{
doublei,x,k,s=0;
scanf("%lf",&x);
k=x;
for(i=1;abs(k)>=0.0000001;i++)
{s+=k;k*=-x*x/(i*2*(i*2+1));}
printf("%.3lf",s);
return0;
}

//运行示例截图:

此时输入为角度值,例如截图中输入30,输出为0.5。

本题属于基础题。很简单的程序,不要人为复杂化。

Ⅳ C语言求sinx

修改了一下。 用 前后项的递推: c=c*x*x/(float)i/(float)(i-1);
#include <stdio.h>
#include <math.h>

int main(){
double x,a,b=1,c=1,sum;
int i,count=1;
scanf("%lf",&x);
sum=x;
for (i=3; fabs(c)>1e-05;i=i+2){
c=c*x*x/(float)i/(float)(i-1);
b= -b;
sum=sum + c*b;
count++;
}
printf("%.3lf %d\n",sum,count);
return 0;
}

Ⅵ C语言编程计算sinx的近似值

#include"stdio.h"
intmain(intargc,char*argv[]){
doublex,s,t,eps;
inti;
printf("Pleaseenterx&eps(R:0<eps<1)... ");
if(scanf("%lf%lf",&x,&eps)!=2||eps<=0||eps>=1){
printf("数手Inputerror,exit... ");
return0;
}
printf("sin(%g)≈",x);
for(s=t=x,x*=x,i=1;t>=eps;i++){
(t*=x)/=((i*i<<2)+i+i);
s+=i&薯咐嫌1?-t:t;
}
printf("%f ",s);
return0;
}

运行简梁样例:

Ⅶ C语言 求sin值

首先,你的测试输入和测试输出的数据是对应不上的,你写错信息了!

输入 3.1415026, 3 的时候,输出才是 -0.07522 。

好了,正确的参考代码如下:

#include<stdio.h>

doublepower(doublex,intn);//计算乘方的函数
doublefact(intn);//计算阶乘的函数

intmain(intargc,charconst*argv[])
{
doublex,s;
intn;
intsign=1;//正负号开关变量,初始状态为正
printf("Pleaseinputadecimalnumberx,apostiveintnumbern: ");
scanf("%lf%d",&x,&n);

for(inti=0;i<=n;i++)
{
s+=sign*power(x,2*i+1)/fact(2*i+1);
sign=-sign;
}

printf("x=%g,n=%d,s=%.5lf ",x,n,s);
return0;
}

//计算x^n
doublepower(doublex,intn)
{
doublep=1;
//这样的循环条件,很简洁。因为函数传入的是形参,也不会对main的变量造成影响。
for(;n--;)
{
p*=x;
}
returnp;
}

//计算n!
doublefact(intn)
{
doublef=1;
//这样的循环条件,很简洁。因为函数传入的是形参,也不会对main的变量造成影响。
for(;n;)
{
f*=n--;
}
returnf;
}

测试截图:(分别测试了角度为 180度、90度、45度的弧度值)

Ⅷ 用C语言求sinx的值,望高人指点

你的factorial是一个函数,好象不可以直接乘以一个整数的吧,还有double
factorial(int
n)是不是需要一个返回值呢。if(n==0)
return
1;只是在n=0的时候有返回值,n!=0就没有了

Ⅸ C语言计算sinx的近似值

/*sinx=x-x^3/3!+x^5/5-x^7/7!...*/
#include<stdio.h>
#include<math.h>
#define ACCURARY 0.00000001

main()
{
int i=1,j=1,k,n=1,x;
printf("漏模sinx=x-x^3/手悄3!+x^5/5-x^7/7!...\n请输入一个x\n");
scanf("%d",&x);
double sinx=0;
for(i=1;fabs(t)>=ACCURARY;i+=2)
{
for(k=1;k<=i;k++)
{n=n*i;}
j++;
t=pow(-1,j)*pow(x,i)/n;
sinx=sinx+t;
}
printf("sin%d=%.8f\n",x,sinx);
}
你编译一下,看看行不,我好久没弄了。毕搜渣

Ⅹ c语言编程,利用泰勒级数求解sinx,输入x值,求解sinx值,保留小数点后6位。

//#include"stdafx.h"//Ifthevc++6.0,withthisline.
#include"stdio.h"
intmain(void){
inti,t;
doublesum,x,tmp,xx;
printf("Inputx(real-360°~+360°)... ");
scanf("%lf",&x);
xx=x,x*=3.1415926535897932/180;printf("%f ",xx);
for(tmp=sum=x,i=2;tmp>1.0E-5;i++){
t=(i<<1)-1;
sum+=i&1?tmp*=(x*x/t/(t-1)):-(tmp*=(x*x/t/(t-1)));
}
printf("sin(%g°)=%.6f ",xx,sum);
return0;
}