算法思想:
读者在做之前可先画一个直角坐标轴,这里在第一象限牵扯到四条直线(y=x+r,y=x-r,y-x+r,y=-x+3*r),画完之后就可以发现这四条直线构成一个菱形,该菱形正好位于以(r,r)为圆心,半径为r的坐标圆中。这样就可以设置一个限制条件,当x,y处于0到2r之间时,满足(y >= x - r) && (y <= x + r) && (y <= -x + 3 * r) && (y >= -x + r)的值就打印星号即可,其余地方打印空格即可。
#include <stdio.h>
#include <stdlib.h>int main()
{
int r=0;
printf("r:");
scanf_s("%d", &r);
int x, y;
for (x = 0; x <= 2 * r; x++)
{
for (y= 0; y<=2 * r; y++)
{
if ((y >= x - r) && (y <= x + r) && (y <= -x + 3 * r) && (y >= -x + r))
{
printf("*");
}
else
{
printf(" ");
}
}
printf("\n");
}
system("pause");
return 0;
}