- 1、本文档共103页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
c语言趣味程序zl
--1.绘制余弦曲线在屏幕上用“*”显示0-360度的余弦函数cos(x)曲线。*问题分析与算法设计
如果在程序中使用数组,这个问题十分简单。但若规定不能使用数组,问题就变得不容易了。
关键在于余弦曲线在0-360度的区间内,一行中要显示两个点,而对一般的显示器来说,只能按行输出,即:输出第一行信息后,只能向下一行输出,不能再返回到上一行。为了获得本文要求的图形就必须在一行中一次输出两个“*”。
为了同时得到余弦函数cos(x)图形在一行上的两个点,考虑利用cos(x)的左右对称性。将屏幕的行方向定义为x,列方向定义为y,则0-180度的图形与180-360度的图形是左右对称的,若定义图形的总宽度为62列,计算出x行0-180度时y点的坐标m,那么在同一行与之对称的180-360度的y点的坐标就应为62-m。程序中利用反余弦函数acos计算坐标(x,y)的对应关系。
使用这种方法编出的程序短小精炼,体现了一定的技巧。*程序代码与注释
#include stdio.h
#include math.hvoid main()
{ double y;int x,m;
for(y=1;y=-1;y-=0.1)//y为列方向,值从-1到1,步长为0.1
{ m=(int)(acos(y)*10);//计算出y对应的弧度m,乘以10为图形放大倍数
for(x=0;xm;x++) printf( );
printf(*);//控制打印左侧的*号
for(;x62-m;x++) printf( );
printf(*\n);//控制打印同一行中对称的右侧*号} }或#include stdio.h
#include math.h
void main()
{ double y;int x,m;
for(y=1;y=-1;y-=0.1)//y为列方向,值从-1到1,步长为0.1
{ m=(int)(acos(y)*10);//计算出y对应的弧度m,乘以10为图形放大倍数
for(x=0;x=62;x++)
{ if(x==m||x==62-m) printf(*);else printf( );} //利用对称性
printf(\n);}}
*思考题如何实现用“*”显示0-360度的sin(x)曲线。
*问题分析与算法设计
注意asin()的返回值是-pi/2到pi/2,以及sin(x)在0-360度之间对称性特点,在上面程序的基础上做一定修改。
*程序注释与说明
#include stdio.h
#include math.h
void main()
{ double y;int x,m;
for(y=1;y=-1;y-=0.1)
{ m=(int)(asin(y)*10);
if(y0)
{ for(x=1;xm;x++) printf( );
printf(*);
for(;x30-m;x++) printf( );
printf(*\n);}
else{ for(x=1;x31-m;x++) printf( );
printf(*);
for(;x62+m;x++) printf( );
printf(*\n);
}
}
}
或者
#include stdio.h
#include math.h
void main()
{ double y;int x,m;
for(y=1;y=-1;y-=0.1)
{ m=(int)(asin(y)*10);
for(x=0;x=62;x++)
{ if(x==m||x==31-m||x==62+m) printf(*);//利用sin(x)的周期性特点
else printf( );}
printf(\n);
}
2.绘制余弦曲线和直线
在屏幕上显示0-360度的cos(x)曲线与直线f(x)=45*(y-1)+31的迭加图形。其中cos(x)图形用“*”表示,f(x)用“+”表示,在两个图形相交的点上则用f(x)图形的符号。
*问题分析与算法设计
本题可以在上题的基础上进行修改。图形迭加的关键是要在分别计算出同一行中两个图形的列方向点坐标后,正确判断相互的位置关系。为此,可以先判断图形的交点,再分别控制打印两个不同的图形。
*程序注释与说明
#include stdio.h
#include math.h
void main()
{ double y;int x,m,n,yy;
for(yy=0;yy=20;yy++) //对于第一个y坐标进行计算并在一行中打印图形
{ y=0.1*yy; //y:屏幕行方向坐标
m=(int)(acos(1-y)*10); //m: cos(x)曲线上y点对应的屏幕列坐标
n=(int)(45*(y-1)+31); //n:直线上y点对应的列坐标
for(x=0
文档评论(0)