网站大量收购独家精品文档,联系QQ:2885784924

西工大C语言大作业习题答案.doc

  1. 1、本文档共22页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
西工大C语言大作业习题答案

童鞋们,快来呀! 答案!答案! no1.绘制余弦曲线 ????在屏幕上用“*”显示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)的对应关系。 ????使用这种方法编出的程序短小精炼,体现了一定的技巧?#includestdio.h #includemath.h void main() { ????double y; ????int x,m; ;y-=0.1)???????? ????{ for(y=1;y=-1 ????????m=acos(y)*10;???????????? ????????for(x=1;xm;x++) printf( ); ????????printf(*);?????????????? ????????for(;x62-m;x++)printf( ); ????????printf(*\\n);???????????? ????} } no2.绘制余弦曲线和直线 ????在屏幕上显示0~360度的cos(x)曲线与直线f(x)=45*(y-1)+31的迭加图形。其中cos(x)图形用“*”表示,f(x)用“+”表示,在两个图形相交的点上则用f(x)图形的符号。 *问题分析与算法设计 ????本题可以在上题的基础上进行修改。图形迭加的关键是要在分别计算出同一行中两个图形的列方向点坐标后,正确判断相互的位置关系。为此,可以先判断图形的交点,再分别控制打印两个不同的图形。 *程序注释与说明 #includestdio.h #includemath.h?? void main() { ????double y; ????int x,m,n,yy; ????for(yy=0;yy=20;yy++) ????{ ????????y=0.1*yy;?????????????????????? ????????m=acos(1-y)*10;?????? ????????n=45*(y-1)+31;?????? ????????for(x=0;x=62;x++)???????????? ????????????if(x==mx==n) printf(+); ????????????else if(x==n) printf(+);?? ????????????else if(x==m||x==62-m) printf(*); ????????????else??printf( );???????????????? ????????printf(\\n); ????} } -------------------------------------------------------------------------------- no3.绘制圆 ????在屏幕上用“*”画一个空心的圆 *问题分析与算法设计 ????打印圆可利用图形的左右对称性。根据圆的方程: ????R*R=X*X+Y*Y ????可以算出圆上每一点行和列的对应关系。 *程序说明与注释 #.h includestdio #includemath.h void main() { ????double y; ????int x,m; ????for(y=10;y=-10;y--) ????{ ????????m=2.5*sqrt(100-y*y);?? ????????for(x=1;x30-m;x++) printf( );???? ????????printf(*);???????????????????????? ????????for(;x30+m;x++) printf( );?????? ????????printf(*\\n);?????????????????????????????? ????} } no4.歌星大奖赛 ??

文档评论(0)

kaiss + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档