在屏幕上用“*”显示0~360度的余弦函数cos(x),sin(x)曲线
来源:互联网 发布:数据库名怎么看 编辑:程序博客网 时间:2024/04/30 22:13
/*绘制余弦曲线: 在屏幕上用“*”显示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<iostream>
#include<cmath>
using namespace std;
int main()
{
double y;
int x,m;
//cos(x)
for(y=1;y>=-1;y-=0.1) //y为列方向,值从1到-1,步长为0.1
{
m=acos(y)*10; //计算出y对应的弧度m,乘以10为图形放大倍数
for(x=1;x<m;x++)
cout<<" ";
cout<<"*"; //控制打印左侧的'*'号
for(;x<62-m;x++)
cout<<" ";
cout<<"*"<<endl; //控制打印同一行中对称的右侧'*'号
}
//sin(x)利用半边对称
for(y=1;y>=0;y-=0.1)
{
m=asin(y)*10;
for(x=1;x<m;x++)
cout<<" ";
cout<<"*";
for(;x<31-m;x++)
cout<<" ";
cout<<"*"<<endl;
}
for(y=0;y>=-1;y-=0.1)
{
m=fabs(asin(y))*10;
for(x=1;x<32+m;x++)
cout<<" ";
cout<<"*";
for(;x<62-m;x++)
cout<<" ";
cout<<"*"<<endl;
}
return 0;
}
- 在屏幕上用“*”显示0~360度的余弦函数cos(x),sin(x)曲线
- 在屏幕上用“*”显示0~360度的余弦函数cos(x)曲线 数组实现
- 在屏幕上用“*”显示0~360度的余弦函数cos(x)曲线
- 绘制余弦曲线——在屏幕上用“*”显示0~360度的余弦函数cos(x)曲线
- 屏幕上显示0~360度的cos(x)曲线与sin(x)的迭加图形。
- 绘制正弦曲线——在屏幕上用“*”显示0~360度的正弦函数sin(x)曲线
- 在屏幕上显示0~360度的cos(x)曲线与直线x=45*(y-1)+31的迭加图形
- 在屏幕上显示0—360的cos(x)曲线与直线f(x)=45*(y-1)+31的迭加图形。
- 实现sin(x)曲线与cos(x)曲线图形的同时显示
- 利用C语言实现sin(x)曲线与cos(x)曲线图形的同时显示
- C语言 程序 绘制余弦曲线和直线 , 绘制cos(x)和sin(x)
- C语言 程序 用*显示cos(x)和sin(x)
- 利用MATLAB绘制隐函数f(x,y)=x^2 * sin(x+y^2)+y^2 * exp(x+y)+5 * cos(x^2+y)=0的曲线
- 写一个用矩形法求定积分的通用函数,分别求:sin(x),cos(x),e^x
- cos x 和sin x图形绘制
- 使用 For 循环的自动索引功能创建数组y1=sin(x/10)和y2=cos(x/10),(x=0-99),并分别用一个波形图和一个波形图表来进行显示。
- java 反射 画Sin、Cos函数曲线
- sin(x)函数的源代码?
- OpenGL-1
- acegi整合CAS (sso)
- 在屏幕上用“*”显示0~360度的余弦函数cos(x)曲线 数组实现
- Javscript Json数据操作(数据增,删,改,查)
- 最新火爆游戏巨献——谈Flash Player的安全机制
- 在屏幕上用“*”显示0~360度的余弦函数cos(x),sin(x)曲线
- 三国地图
- Informix Online数据库日常管理及维护
- LDAP
- 【转载】刘未鹏的C++学习历程 + 小诗一首
- 排序法比较(C++)
- LDAP
- Linux中tty、 pty、pts的概念区别
- liferay5.1.2note