日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營(yíng)銷解決方案
萬(wàn)花模擬器(C/C++基礎(chǔ))

還記得小時(shí)候玩的萬(wàn)花尺么?好好玩,各種不同的點(diǎn)距能畫出各種各樣形狀圖形。

成都創(chuàng)新互聯(lián)公司主營(yíng)雙流網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,成都App制作,雙流h5小程序設(shè)計(jì)搭建,雙流網(wǎng)站營(yíng)銷推廣歡迎雙流等地區(qū)企業(yè)咨詢

C語(yǔ)言程序萬(wàn)花尺模擬

函數(shù)功能:每隔5秒隨機(jī)生成萬(wàn)花圖形 并自動(dòng)保存作圖參數(shù)以及圖形到當(dāng)前目錄,圖像格式為jpg

提示:

  • 相關(guān)參數(shù)范圍可以自行設(shè)置,用自定義mySetRand函數(shù)設(shè)置作圖尺寸范圍

注意:

  • 內(nèi)圓半徑不能大于外圓半徑,內(nèi)圓作圖點(diǎn)不能大于內(nèi)圓半徑

/*以下是完整代碼,可自行個(gè)性化更改參數(shù)*/

 
 
 
  1. #include  
  2. #include  
  3. #include  
  4. #include  
  5. #include  
  6. #include  
  7. int mySetRand(int num, int min, int max);  
  8. #define PI 3.1415926536  
  9. int main()  
  10. {  
  11. int k = 0;  
  12. wchar_t s[255] = { NULL };  
  13. int R; // 靜圓半徑  
  14. int r; // 動(dòng)圓半徑  
  15. int dr; // 動(dòng)圓上的作圖點(diǎn)到圓心的距離  
  16. while (1)  
  17.  
  18. //產(chǎn)生一個(gè)100-395之間的隨機(jī)數(shù)  
  19. R = mySetRand(1, 100, 395);  
  20. r = R - mySetRand(1, 5, 95);  
  21. dr = r - mySetRand(1,2, r-5);  
  22. // 求執(zhí)行次數(shù)(最小公倍數(shù)/靜圓半徑)  
  23. int m = R, n = r;  
  24. int tmp;  
  25. while (n != 0)  
  26.  tmp = m % n;  
  27. m = n;  
  28. n = tmp;  
  29. }  
  30. double maxdegree = r / m * 2 * PI;  
  31. //清屏  
  32. //cleardevice();  
  33. system("cls");  
  34. initgraph(800, 610);  
  35. setbkcolor(RGB(200, 200, 200));  
  36. // 設(shè)置作圖原點(diǎn)坐標(biāo),使其在窗口中心畫圖  
  37. setorigin(400, 300);  
  38. // 開始繪圖  
  39. int x, y;  
  40. for (double degree = 0; degree < maxdegree; degree += 0.01)  
  41. {  
  42. x = (int)(dr * cos(degree*(double(R) / r - 1)) + (R - r) * cos(degree));  
  43. y = (int)(dr * sin(degree*(double(R) / r - 1)) - (R - r) * sin(degree));  
  44. putpixel(x, y, RGB(255,255,0));  
  45. }  
  46. //歸位原點(diǎn)坐標(biāo)  
  47. setorigin(0, 0);  
  48. _stprintf_s(s, _T("作圖參數(shù):外圓半徑%.3d像素\\內(nèi)圓半徑%.3d像素\\作圖點(diǎn)到圓心距離%.3d像素"), R, r, dr);  
  49. settextstyle(20, 0, _T("黑體")); 
  50.  settextcolor(RED);  
  51. outtextxy(60, 587, s);  
  52. //保存圖形到當(dāng)前目錄  
  53. k++;  
  54. _stprintf_s(s, _T("%.6d.jpg"), k);  
  55. saveimage(s);  
  56. //畫面停留5秒后,清屏重新畫另一個(gè)圖  
  57. Sleep(5000);  
  58. closegraph();  
  59. }  
  60. return 0;  
  61. }  
  62. //指定范圍隨機(jī)數(shù)產(chǎn)生  
  63. //num產(chǎn)生個(gè)數(shù),產(chǎn)生范圍min到max(包括min和max)  
  64. int mySetRand(int num, int min, int max)  
  65. {  
  66. int *p_num = #  
  67. int *p_min = &min;  
  68. int *p_max = &max;  
  69. int a = 0;  
  70. int p1 = 0, p2 = 0;  
  71. if ((*p_num)<0 || (*p_min>*p_max))  
  72. {  
  73. printf("最大值與最小值反過(guò)來(lái)了?\n元素個(gè)數(shù)為負(fù)數(shù)了?");  
  74. getchar();  
  75. return -1;  
  76. }  
  77. srand((unsigned int)time(0));  
  78. for (size_t i = 0; i < *p_num; i++)  
  79. {  
  80. a = rand(); 
  81.  if (*p_min == 0) 
  82.  { 
  83.  
  84. p2 = a % (*p_max + 1);  
  85.  
  86. else if (*p_min>0)  
  87. {  
  88. p1 = a / (*p_max - *p_min + 1);  
  89. p2 = a - p1*(*p_max - *p_min + 1) + *p_min; 
  90.  }  
  91. else  
  92.  printf("處理出錯(cuò)!");  
  93. getchar(); 
  94.  return -2;  
  95. }  
  96. if (p2>*p_max || p2<*p_min)  
  97.  printf("數(shù)據(jù)有誤!");  
  98. getchar();  
  99. }  
  100.  return p2;  

//部分代碼截圖以及效果圖展現(xiàn)如下


當(dāng)前題目:萬(wàn)花模擬器(C/C++基礎(chǔ))
本文URL:http://www.5511xx.com/article/cdipgio.html