十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
没有现成的函数,你可以以0.01为步长循环
目前创新互联建站已为超过千家的企业提供了网站建设、域名、虚拟主机、网站托管运营、企业网站设计、钟祥网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。
y的坐标为sin(x)
然后再在输出上画一个点(x,sin(x));
这样从-PI循环到PI,就可以画一个周期的正玄图形了。
画点函数为:void putpixel(int x, int y, int color)
其中x,y为坐标,color是颜色。
头文件为:graphics.h
这是在tc编译器下的。需要先打开图形工作模式。
#include stdio.h
#include math.h
main()
{
double y;
int x,m;
for(y=1;y=-1.0;y-=0.1)
{
m=acos(y)*10;
for(x=1;xm;x++)
printf(" ");
printf("*");
for(;x62-m;x++)
printf(" ");
printf("*\n");
}
}
hehe
首先这个程序只能输出这种 不像正弦 也不象余弦的曲线。
因为你的程序的算法是每行有2个星星
其次,15+45=60,约等于2*PI
就是说,前面的15是PI/2,后面的45是PI/2*3,
输出的是1个周期的。sin(PI/2)=1。。这回懂了么?
首先,你输出的不是正弦图像,而是反正弦图像。
#includestdio.h
#includemath.h
int
main(){
double
y;
int
x,m,i;
printf("y=sin(x)
[0x2*pi]\n");
for(y=1;y=-1;y-=0.1){//表示y的取值范围是[-1,1]
if(y=0){
m=asin(y)*10;
//反正弦函数,确定空格的数量,最大值为15
for(x=1;xm;x++)printf("
");
//printf("*",m);
printf("*");//注意此时不换行,因为后面还有一个点
for(;x31-m;x++)printf("
");//输出第二个点,并换行
printf("*\n");}
else{//同理输出y小于0的点
m=-1*asin(y)*10;
for(i=0;i32;i++)printf("
");
for(x=1;xm;x++)printf("
");
//printf("*",m);
printf("*");
for(;x31-m;x++)printf("
");
printf("*\n",m);
}
}
getchar();
return
0;
}
1、首先,打开VS2019,并且创建一个C语言源文件,会看到如下的页面。
2、鼠标在下图红色圈所示的区域单击一下。
3、之后,再按Enter键,会看到新的一行。
4、在这一行中输入:#includemath.h。
5、接着,在void main()中去定义一个单精度型变量。
6、定义完回车后,输入a=sin(90);注意,90指的是90弧度。
7、再次回车,输入printf("%f",a);。
8、可以按F5键去运行这段程序,会看到如下的结果。即90弧度的正弦值约为0.893997。
1、C语言中要编写sin函数,实质上要利用sin的泰勒公式,然后根据泰勒公式,将其中的每一项进行分解,最后用循环,累加计算出最终结果。
2、下面用for循环实现sin的算法,程序代码如下:
#includestdio.h
#includemath.h
void main()
{
int i;
float x,sum,a,b; //sum代表和,a为分子,b为分母
char s;
printf("please input x");
scanf("%f",x);
s=1;
sum=0;
a=x; //分母赋初值
b=1; //分子赋初值
for(i=1;a/b=1e-6;i++)
{
sum=sum+s*a/b; //累加一项
a=a*x*x; //求下一项分子
b=b*2*i*(2*i+1); //求下一项分母
s*=-1;
}
printf("sum=%f\n",sum);
}
3、 关于上述程序的几点说明:上述程序的计算结果精确到小数点后六位;上述程序运用了sin的泰勒展开式 sin x=x-x^3/3!+x^5/5! ...... ,程序中将sin泰勒公式中的每一项拆成了分子,分母以及每一项前的符号这三项,以便于每一项的累加。