C语言绘制余弦、正弦曲线

软件发布|下载排行|最新软件

当前位置:首页IT学院IT技术

C语言绘制余弦、正弦曲线

  2021-04-03 我要评论

绘制余弦曲线

要求:在屏幕上用“*”(星号)显示0°~360°的余弦函数cos(x)曲线。(不使用数组)

问题分析与算法设计

对一般的显示器来说,只能按行输出,即:输出第一行信息后,想能向下一行输出,不能再返回到上一行。为了获得一个周期(0°~360°)的余弦函数图形,j就必须在一行中一次输出两个“*”。

为了同时得到余弦函数cos(x)图形在一行上的两个点,考虑利用cos(x)的左右对称性。将屏幕行方向定义为x,列方向定义为y。若定义图形的总宽度为62行,计算出x行0°~180°时y点坐标m,那么在同一行与之对称的180°~360°的y点坐标就应为62-m。程序中利用反余弦函数acos计算坐标(x,y)的对用关系。

程序说明与注释

/****************绘制0~2PI区间内的余弦曲线****************/
/***********编者:董炳政******编写时间2018/07/20**********/
/*******************************************************/
#include <stdio.h>
#include <math.h>
 
int main()
{
  double y;          /*纵坐标y*/
  int x,m;          /*横坐标x*/
  for(y = 1;y >= -1;y -= 0.1) /*纵轴y从1~-1,步长为0.1*/
  {
    m=acos(y)*10;      /*利用math.h中的反余弦函数,求对应横坐标的值,此时m为int型变量*/
    for(x = 1;x < m;x++)  /*开始逐行打点*/
      printf(" ");    /*在曲线定点右侧,打印空格*/
    printf("*");      /*第一个曲线定点打印“*”*/
    for(;x < 62-m;x++)   /*开始打印对称曲线定点,由于对称性x的终值为62-m*/
      printf(" ");    /*在两定点之间打印空格*/
    printf("*\n");     /*第二个曲线定点打印“*”,并换行*/
  }
  return 0;
}

运行结果:

[root@localhost 1_drawingcos]# ./drawingcos 
*                               *
  *                           *
   *                         *
   *                        *
    *                      *
     *                     *
     *                    *
      *                   *
      *                  *
       *                 *
       *                *
        *               *
        *              *
         *             *
         *            *
          *           *
           *         *
           *        *
            *       *
             *     *
               **

绘制正弦曲线

在已经会绘制余弦曲线的基础上,我们来进一步探索如何利用C语言绘制正弦函数。

问题分析:

很自然的,我们想到将acos(y)换成asin(y),不就可以把画余弦函数换成画正弦函数了吗。可是,事实并没有那么简单。首先,0°~360°的正弦函数并不是一个简单的左右对称的图形;其次,反三角函数x=asin(y)的值域为(-π/2,π/2),所以并不能通过简单的求反三角函数值计算出(π,2π)这一段图形的横坐标。

这里提供一种方法。我们可以通过计算asin(y)来得到(0,π/2)这一段图形的横坐标;利用(0,π/2)的图形和(π/2,π)关于x=π/2轴对称,来得到(π/2,π)这一段图形的横坐标;通过计算π+asin(-y)的值,来得到(π,2π)这一段图形的横坐标。

/****************绘制0~2PI区间内的弦曲线****************/
/***********编者:董炳政******编写时间2018/07/20**********/
/*******************************************************/
#include <stdio.h>
#include <math.h>
#define PI 3.14159
 
int main()
{
  double y;          /*纵坐标y*/
  int x,m;          /*横坐标x*/
  for(y = 1;y >= 0;y -= 0.1) /*先求0~PI,纵轴y从1~0,步长为0.1*/
  {
    m=asin(y)*10;      /*利用math.h中的反正弦函数,求对应横坐标的值,此时m为int型变量*/
    for(x = 1;x < m;x++)  /*开始逐行打点*/
      printf(" ");    /*在曲线定点右侧,打印空格*/
    printf("*");      /*第一个曲线定点打印“*”*/
    for(;x < 31-m;x++)   /*开始打印对称曲线定点,由于0~PI的对称性x的终值为31-m*/
      printf(" ");    /*在两定点之间打印空格*/
    printf("*\n");     /*第二个曲线定点打印“*”,并换行*/
  }
  for(y -= 0.1;y >= -1;y -= 0.1)
  {
    m=(PI+asin(-y))*10;   
    for(x=1;x<m;x++)
      printf(" ");
    printf("*\n");
    for(;x<(62-(m-31));x++)
      printf(" ");
    printf("*\n");
  }
  return 0;
}

运行结果:

[root@localhost 1_drawingcos]# ./drawingsin 
       * *
     *     *
    *       *
   *         *
   *          *
  *           *
  *            *
 *             *
 *              *
*               *
*               *
                *              *
                 *             *
                 *            *
                  *           *
                  *          *
                   *        *
                    *       *
                     *     *
                       **
您可能感兴趣的文章:

Copyright 2022 版权所有 软件发布 访问手机版

声明:所有软件和文章来自软件开发商或者作者 如有异议 请与本站联系 联系我们