问题描述:
要求在main()函数中调用show_sin_table(min_angle, max_angle),显示角度值为min_angle到max_angle之间的所有角度(间隔为1度)的正弦值。要求不能用数学库函数,可以将项目“太乐了”中的mysin函数拷贝到这个程序中,用于计算sin值。例如show_sin_table(0, 90)可以显示出所有0到90度的正弦值。可以考虑以速查表格的形式(例,单位转换对照表)给出结果。
#include "stdafx.h"
//下面加入常变量和自定义函数的声明
void show_sin_table(int a, int b);
double myabs(double x);
double mysin(double x);
int main()
{
show_sin_table(0, 90);
show_sin_table(135, 180);
return 0;
}
//下面定义show_sin_table()函数
void show_sin_table(int a, int b)
{
int diffe, i ,j;
diffe = b - a;
i = diffe / 10;
j = diffe % 10;
printf("%d+",a);
int n(0);
while (n <= i)
{
printf("\t%7d", n);
n++;
}
printf("\n");
double value;
int m(0), n1;
while (m <= 9)
{
printf("%7d\t", m);
n1 = 0;
while (n1 <= i)
{
value = mysin ( 3.1415926*(a+n1*10+m)/180 );
if (value>=0)
printf(" %.3lf\t",value);
else
printf(" %.3lf\t", value);
n1++;
}
m++;
printf("\n");
}
printf("\n\n");
}
//下面定义myabs函数
double myabs(double x)
{
return ((x >= 0) ? x : -x);
}
//下面定义mysin函数
double mysin(double x)
{
double sum = x, x_pow = x, item, fact = 1;
int n = 1, sign = 1; //定义变量时赋初值,已经将第一项考虑到累加和sum中
do
{
fact = fact * (n + 1)*(n + 2); //fact用于表示阶乘,在公式中作分母
x_pow *= x * x; //x_pow是分子中用于表示阶乘,在公式中作分母
sign = -sign; //确定即将要累加的这一项的符号
item = x_pow / fact * sign; //计算出要累加的项
sum += item; //将该项累加上去
n += 2;
} while (myabs(item)>1e-5);
return sum;
}
输出效果:
=