基于过程的sin函数的计算
2015-09-07 16:48
429 查看
基于泰勒展开式,我们可以方便的计算正弦函数的值,那么如果要求不能使用函数呢,可能会带来点小麻烦,下面是纯过程的正弦函数的计算,精度可控
<span style="font-size:24px;">#include <iostream>
#include <stdio.h>
using namespace std;
int main()
{
double x;
double sin_res=0;//正弦结果
double sin_res_before=0;
int sin_presicion=1e-4;//sin循环次数
int PI_precision=1000000;//PI循环次数
int flag;//正负号
int deep;//当前阶数
double mol;//分子
double den;//分母
double PI=0;
//计算PI
{
flag=1;
mol=4.0;
den=1.0;
for(int i=0; i<PI_precision; i++)
{
//printf("num=%lg\n",(flag)*(mol/den));
PI+=(flag)*(mol/den);
flag=-flag;
den+=2.0;
}
}
x=PI*0.25;
//第一问
{
printf("k ");
for(double i=0; i<=1.0; i+=0.1)
{
printf("%-7lg",i);
}
printf("\n");
printf("sin ");
for(double i=0; i<=1.0; i+=0.1)
{
x=i*PI/2.0;
sin_res=0;
sin_res_before=-1;
flag=1;//初始化
deep=1;
mol=x;
den=1.0;
while((sin_res-sin_res_before)>sin_presicion)
{
//printf("mol=%lg,den=%lg\n",mol,den);
sin_res_before=sin_res;
sin_res+=flag*(mol/den);
deep+=2;
mol*=x*x;
den*=deep*(deep-1);
flag=-flag;
}
printf("%.4lf ",sin_res);
}
printf("\n");
}
//第二问
{
}
/*
//计算级数展开式
{
flag=1;//初始化
deep=1;
mol=x;
den=1.0;
for(int p=0; p<sin_presicion; p++)
{
//printf("mol=%lg,den=%lg\n",mol,den);
sin_res+=flag*(mol/den);
deep+=2;
mol*=x*x;
den*=deep*(deep-1);
flag=-flag;
}
}
printf("sin(%lg)=%lg\n",x,sin_res);
*/
return 0;
}
</span>
<span style="font-size:24px;">#include <iostream>
#include <stdio.h>
using namespace std;
int main()
{
double x;
double sin_res=0;//正弦结果
double sin_res_before=0;
int sin_presicion=1e-4;//sin循环次数
int PI_precision=1000000;//PI循环次数
int flag;//正负号
int deep;//当前阶数
double mol;//分子
double den;//分母
double PI=0;
//计算PI
{
flag=1;
mol=4.0;
den=1.0;
for(int i=0; i<PI_precision; i++)
{
//printf("num=%lg\n",(flag)*(mol/den));
PI+=(flag)*(mol/den);
flag=-flag;
den+=2.0;
}
}
x=PI*0.25;
//第一问
{
printf("k ");
for(double i=0; i<=1.0; i+=0.1)
{
printf("%-7lg",i);
}
printf("\n");
printf("sin ");
for(double i=0; i<=1.0; i+=0.1)
{
x=i*PI/2.0;
sin_res=0;
sin_res_before=-1;
flag=1;//初始化
deep=1;
mol=x;
den=1.0;
while((sin_res-sin_res_before)>sin_presicion)
{
//printf("mol=%lg,den=%lg\n",mol,den);
sin_res_before=sin_res;
sin_res+=flag*(mol/den);
deep+=2;
mol*=x*x;
den*=deep*(deep-1);
flag=-flag;
}
printf("%.4lf ",sin_res);
}
printf("\n");
}
//第二问
{
}
/*
//计算级数展开式
{
flag=1;//初始化
deep=1;
mol=x;
den=1.0;
for(int p=0; p<sin_presicion; p++)
{
//printf("mol=%lg,den=%lg\n",mol,den);
sin_res+=flag*(mol/den);
deep+=2;
mol*=x*x;
den*=deep*(deep-1);
flag=-flag;
}
}
printf("sin(%lg)=%lg\n",x,sin_res);
*/
return 0;
}
</span>
相关文章推荐
- Mootools 1.2教程 函数
- autoit InputBox 函数
- BGP邻居协商过程
- 计算WWW在线人数
- 文件遍历排序函数
- C#使用加边法计算行列式的值
- Oracle 函数大全[字符串函数,数学函数,日期函数]第1/4页
- delphi 正弦曲线图
- ASP下经常用的字符串等函数参考资料
- PostgreSQL教程(五):函数和操作符详解(1)
- DOS批处理 函数定义与用法
- asp Chr 函数 数字转字母的方法
- 计算机信息处理
- Lua中的函数精讲笔记
- Lua中的闭合函数、非全局函数与函数的尾调用详解
- Lua中调用C++函数示例
- Lua实现split函数
- Lua常用时间函数使用实例
- Lua函数与字符串处理简明总结
- Lua学习笔记之表和函数