| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2048 人关注过本帖
标题:y=sin(x)的源程序
取消只看楼主 加入收藏
yiyier
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-3-8
收藏
 问题点数:0 回复次数:3 
y=sin(x)的源程序
请大家帮忙写一下y=sin(x)的源程序,不能用库函数
注意精度问题,终止循环不是用#define N XXXX i<=N
谢谢~~~
搜索更多相关主题的帖子: 源程序 sin 精度 XXXX define 
2006-03-09 12:50
yiyier
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-3-8
收藏
得分:0 
离散公式是
sin x=x-x^3/3!+x^5/5!-...+(-1)^(n-1)*x^(2n-1)/(2n-1)!+...
(这里x是弧度)
2006-03-09 13:08
yiyier
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-3-8
收藏
得分:0 
各位大哥帮忙~~~
2006-03-09 18:31
yiyier
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-3-8
收藏
得分:0 

#define k 50
#define pi 3.1415926

double factorial(int z) /*阶乘,递归算法实现*/
{if(z==0||z==1)
return (1);
else
return (factorial(z-1)*z);
}

double mysin(double x)
{
int n;
long double v;
double y=0,o,p;
for(n=1;n<k;n++)
{
v=factorial(n*2-1);
o=pow((-1),(n-1));
p=pow(x,(n*2-1));
y=y+(o*p/v);
/*
printf("%f %f %f %f\n",v,o,p,y);
*/
}
return(y);
}

void main()
{
float x;
double y,temp;
printf("Enter the randian:");
scanf("%f",&x);
if (x>pi)
{
temp=-2*pi;
while(x>pi)
{
x+=temp;
}
}
if (x<-pi)
{
temp=2*pi;
while(x<-pi)
{
x+=temp;
}
}
y=mysin(x);
printf("sinx:%f\nmysinx:%f\ndisparity:%f%",sin(x),y,(1-sin(x)/y)*100);
getch();
}


怎样把#define k 50
去掉,然后设立另一个方法跳出循环~~~

2006-03-09 18:49
快速回复:y=sin(x)的源程序
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.023280 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved