您好,登錄后才能下訂單哦!
本文實例為大家分享了C語言控制臺繪制曲線的具體代碼,供大家參考,具體內容如下
首先我們應該要知道曲線的方程,這里以直角坐標為例
設我們曲線方程為 y = f(x)
然后我們把它化成 y - f(x) = 0的形式
在程序中,我們檢測每一個(x, y)位置,只要滿足 y - f(x) = 0我們就畫出這個點,反之就用空格填充
而在實際中為了減小誤差,只要 | y - f(x) | < exp, 其中exp是一個誤差范圍,取10^-5就可以了
但是還是因為誤差,只畫曲線的輪廓的話,看起來就不太連續,斷斷續續的(把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; }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。