雷火电竞-中国电竞赛事及体育赛事平台

歡迎來到入門教程網!

C語言

當前位置:主頁 > 軟件編程 > C語言 >

C語言控制臺繪制曲線的實現(xiàn)代碼

來源:本站原創(chuàng)|時間:2020-01-10|欄目:C語言|點擊:

本文實例為大家分享了C語言控制臺繪制曲線的具體代碼,供大家參考,具體內容如下

首先我們應該要知道曲線的方程,這里以直角坐標為例

設我們曲線方程為 y = f(x)

然后我們把它化成 y - f(x) = 0的形式

在程序中,我們檢測每一個(x, y)位置,只要滿足 y - f(x) = 0我們就畫出這個點,反之就用空格填充

而在實際中為了減小誤差,只要 | y - f(x) | < exp, 其中exp是一個誤差范圍,取10^-5就可以了

但是還是因為誤差,只畫曲線的輪廓的話,看起來就不太連續(xù),斷斷續(xù)續(xù)的(把exp調大一點可能是一個方法)

但對于封閉的曲線我們可以畫成實心的,這樣只需要 y - f(x) <(=) 0 就可以了,相反,空心的則是y - f(x) >(=) 0

比如我要畫一個心形線,百度到它的方程為

然后就可以開始寫代碼了。

把其中的注釋去掉就可以輸出到文件中了

#include <stdio.h>
#include <math.h>
 
int main()
{
 //FILE *fp = fopen("graph.txt", "w+");
 float x, y, f;
 for(y = 1.6; y >= -1.6; y -= 0.15){
 for(x = -1.1; x <= 1.1; x += 0.05){
  f = x*x + pow(y - pow(x*x, 1.0/3), 2) - 1; //函數方程 
  //fputc(f <= 1E-5 ? '*' : ' ', fp);
  putchar(f <= 1E-5 ? '*' : ' ');
 }
 //fputc('\n', fp);
 putchar('\n');
 }
 
 for(y = 1.6; y >= -1.6; y -= 0.15){
 for(x = -1.1; x <= 1.1; x += 0.05){
  f = x*x + pow(y - pow(x*x, 1.0/3), 2) - 1; //函數方程 
  //fputc(f > 1E-5 ? '*' : ' ', fp);
  putchar(f > 1E-5 ? '*' : ' ');
 }
 //fputc('\n', fp);
 putchar('\n');
 }
 //fclose(fp);
 return 0;
}

再來一個四葉玫瑰線的代碼:

#include <stdio.h>
#include <math.h>
 
int main()
{
 //FILE *fp = fopen("graph.txt", "w+");
 float x, y, a = 1.0, f;
 for(y = a + 0.3; y >= -a - 0.3; y -= 0.1){
 for(x = -a - 0.3; x <= a + 0.3; x += 0.05){
  f = pow(x*x + y*y, 3) - a*a * pow(x*x - y*y, 2); //函數方程 
  //fputc(f <= 1E-5 ? '*' : ' ', fp);
  putchar(f <= 1E-5 ? '*' : ' ');
 }
 //fputc('\n', fp);
 putchar('\n');
 }
 
 for(y = a + 0.3; y >= -a - 0.3; y -= 0.1){
 for(x = -a - 0.3; x <= a + 0.3; x += 0.05){
  f = pow(x*x + y*y, 3) - a*a * pow(x*x - y*y, 2); //函數方程 
  //fputc(f > 1E-5 ? '*' : ' ', fp);
  putchar(f > 1E-5 ? '*' : ' ');
 }
 //fputc('\n', fp);
 putchar('\n');
 }
 //fclose(fp);
 return 0;
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持我們。

上一篇:opencv3.0識別并提取圖形中的矩形的方法

欄    目:C語言

下一篇:Opencv透視變換綜合實例詳解

本文標題:C語言控制臺繪制曲線的實現(xiàn)代碼

本文地址:http://www.jygsgssxh.com/a1/Cyuyan/276.html

網頁制作CMS教程網絡編程軟件編程腳本語言數據庫服務器

如果侵犯了您的權利,請與我們聯(lián)系,我們將在24小時內進行處理、任何非本站因素導致的法律后果,本站均不負任何責任。

聯(lián)系QQ:835971066 | 郵箱:835971066#qq.com(#換成@)

Copyright © 2002-2020 腳本教程網 版權所有