C语言万花尺模拟程序

万花尺相信很多人小时候都玩过吧,将一个满是齿牙的小圆套在一个大圆里面,用笔放进小圆的洞里,然后转圈圈画,就可以画出很多美丽有趣的图案。这个程序就是万花尺的模拟程序。

下面是几组数据和执行效果的抓图:

代码展示:


// 程序名称:万花尺(又名万花规)模拟程序
// 编译环境:Visual C++ 6.0,EasyX 2011

#include <graphics.h>
#include <stdio.h>
#include <conio.h>
#include <math.h>
#define PI 3.1415926536

void main()
{
	int R;		// 外部静圆半径
	int r;		// 内部动圆半径
	int dr;		// 内部动圆上的作图点到圆心的距离

begin:
	// 获取用户输入
	printf("请输入外部静圆半径(小于 240):");
	scanf("%d",&R);
	printf("请输入内部动圆半径(小于静圆半径):");
	scanf("%d",&r);
	printf("请输入内部动圆上的作图点到圆心的距离(小于动圆半径):");
	scanf("%d",&dr);
	system("cls");

	// 求执行次数(最小公倍数/静圆半径)
	int m = R, n = r;
	int tmp;
	while(n != 0)
	{
		tmp = m % n;
		m = n;
		n = tmp;
	}
	double maxdegree = r / m * 2 * PI;

	// 初始化
	initgraph(640, 480);	// 创建绘图窗口
	setorigin(320, 240);	// 设定圆心坐标
	
	// 绘图
	int x, y;
	for(double degree = 0; degree < maxdegree; degree += 0.01)
	{
		x = (int)(dr * cos(degree*(double(R) / r - 1)) + (R - r) * cos(degree));
		y = (int)(dr * sin(degree*(double(R) / r - 1)) - (R - r) * sin(degree));
		putpixel(x, y, GREEN);
	}
	outtextxy(-320, 220, _T("绘制完毕,按 ESC 退出,按其他键重新开始"));

	// 重新开始,或退出程序
	char c = getch();
	closegraph();
	if (c != 27) goto begin;
}

END


自学编程的小伙伴们不容易,在学习编程的路上会遇到很多瓶颈,甚至会感到迷茫,为此我给大家整理了一些资源福利,都放在下方啦,还可以和群里的小伙伴们一起来学习交流嗷~

C/C++编程学习基地icon-default.png?t=MBR7https://jq.qq.com/?_wv=1027&k=EcWDuljX

猜你喜欢

转载自blog.csdn.net/weixin_58045538/article/details/128469618