谢尔宾斯基三角形
谢尔宾斯基三角形如下所示:
#include #include //自定义函数,绘制谢尔宾斯基三角形,参数为3个顶点坐标 void sb(float x1, float y1, float x2, float y2, float x3, float y3) { if (abs(x1 - x2) + abs(x2 - x3) + abs(x3 - x1) + abs(y1 - y2) + abs(y2 - y3) + abs(y3 - y1) < 20) { moveto(x1, y1); lineto(x2, y2); //绘制三角形 lineto(x3, y3); lineto(x1, y1); } else//否则绘制3个小谢尔宾斯基三角形 { sb(x1, y1, (x1 + x2) / 2, (y1 + y2) / 2, (x1 + x3) / 2, (y1 + y3) / 2); sb((x1 + x2) / 2, (y1 + y2) / 2, x2, y2, (x2 + x3) / 2, (y2 + y3) / 2); sb((x1 + x3) / 2, (y1 + y3) / 2, (x2 + x3) / 2, (y2 + y3) / 2, x3, y3); } }
int m