日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

用计算机语言画曲线,用C语言控制台画简单的曲线

發布時間:2024/9/30 编程问答 27 豆豆
生活随笔 收集整理的這篇文章主要介紹了 用计算机语言画曲线,用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

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

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

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

#include #include 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 #include 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;

}

總結

以上是生活随笔為你收集整理的用计算机语言画曲线,用C语言控制台画简单的曲线的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。