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)的对应关系。
使用这种方法编出的程序短小精炼,体现了一定的技巧。
程序说明与注释。
#include<>
#include<>
void main()
double y;
int x,m;
for(y=1;y>=-1;y-=0.1)
m=acos(y)*10;
for(x=1;x
no2.绘制余弦曲线和直线。
在屏幕上显示0~360度的cos(x)曲线与直线f(x)=45*(y-1)+31的迭加图形。其中cos(x)图形用“*”表示,f(x)用“+”表示,在两个图形相交的点上则用f(x)图形的符号。
问题分析与算法设计。
本题可以在上题的基础上进行修改。图形迭加的关键是要在分别计算出同一行中两个图形的列方向点坐标后,正确判断相互的位置关系。为此,可以先判断图形的交点,再分别控制打印两个不同的图形。
程序注释与说明。
#include<>
#include<>
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==m&&x==n) printf("+
else if(x==n) printf("+
else if(x==m||x==62-m) printf("*
elseprintf("
printf("");
no3.绘制圆。
在屏幕上用“*”画一个空心的圆。
问题分析与算法设计。
打印圆可利用图形的左右对称性。根据圆的方程:
r*r=x*x+y*y
可以算出圆上每一点行和列的对应关系。
程序说明与注释。
#include<>
#include<>
void main()
double y;
int x,m;
for(y=10;y>=-10;y--)
m=2.5*sqrt(100-y*y);
for(x=1;x<30-m;x++)printf("
printf("*
for(;x<30+m;x++)printf("
printf("*n");
西工大c大作业
摘要。c 大作业对于我这个接触一学期不到的程序猿来书说是一个不限的挑战。从最初的选题到到程序编完调试完历时十多天,通过编写这一个压缩与解压缩软件,我对文件,结构体,链表有了更深的了解。期间我通过查阅资料确定了使用huffman压缩与解压缩算法,然后通过学习对huffman算法有了初步的了解,掌握了遍...
西工大公差大作业
公差与技术测量。机械精度设计报告 齿轮油泵精度设计。学院 班级 专业 学号 姓名 目录。1.目的与要求。2.要求完成的任务。3.零件图分析。3.1尺寸公差分析。3.2几何精度分析。3.3表面粗糙度分析。4.装配图配合分析。5.总结与反思。参考文献。注 分析的装配零部件选自机械制图并适当改动其参数以方...
西工大模式分类作业
模式分类。请独立完成以下问题,并提交 文件和纸质答题册,纸质答题册不允许打印。标红的为 题。1.用matlab模拟生成两个样本,并计算样本之间的马氏距离。2.基于最基本的近邻准则分类思想,给出几类类似的方法,并评述这些方法和线性分类 非线性分类和统计分类等方法相比,在什么情况下比后述方法效果差,在什...