| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2048 人关注过本帖
标题:y=sin(x)的源程序
只看楼主 加入收藏
yiyier
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2006-3-8
收藏
 问题点数:0 回复次数:7 
y=sin(x)的源程序
请大家帮忙写一下y=sin(x)的源程序,不能用库函数
注意精度问题,终止循环不是用#define N XXXX i<=N
谢谢~~~
搜索更多相关主题的帖子: 源程序 sin 精度 XXXX define 
2006-03-09 12:50
sunnvya
Rank: 5Rank: 5
等 级:贵宾
威 望:17
帖 子:1094
专家分:0
注 册:2005-11-23
收藏
得分:0 
数学功底,摸清求SIN(X)的原理,
可我数学给忘了.
呵呵
给我点提示就能编出来

http://www. 第二站>>>提供源码下载
2006-03-09 12:59
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
ヤ順祺冄繎ヤ
Rank: 8Rank: 8
等 级:贵宾
威 望:42
帖 子:3032
专家分:0
注 册:2005-11-9
收藏
得分:0 

#include<stdio.h>
#include<math.h>
main()
{
float sin=0.0,repl,x;
int j,i;
printf("请输入X的值\n");
Scanf("%f",&x);
for(i=1,j=1;sin>=-1||sin<=1;i++,j+=2)
{ repl=pow(x,j)/a(j);
if (i%2==0)
sin-=repl;
else
sin+=repl;
}
printf("sin(X)=%f",sin);
}
long a(int x)
{
int i;
long s=1;
for(i=1;i<=x;i++)
s*=i;
return s;
}


我看了一下,不知道是不是这样,错了你们指正一下;

[此贴子已经被作者于2006-3-9 13:24:09编辑过]

2006-03-09 13:21
kyako
Rank: 1
等 级:新手上路
帖 子:41
专家分:0
注 册:2006-3-6
收藏
得分:0 
不能调库函数。。。。。

2006-03-09 16:23
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
feng1256
Rank: 4
等 级:贵宾
威 望:14
帖 子:2899
专家分:0
注 册:2005-11-24
收藏
得分:0 

楼主搜索再搜索~这问题最近问了4,5次了


叁蓙大山:工謪、稅務、嗣發 抱歉:不回答女人的问题
2006-03-09 22:21
快速回复:y=sin(x)的源程序
数据加载中...
 
   



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

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