题目:给一个2r的正方形,中心为(r,r)d为正方形内及其边上整点(i,j)到(r,r)的距离,如果(i,j)对应的的,满足|d*d-r*r|<=3,将(i,j)这个点设为*,否则有空格,最后输出这个正方形
#include<iostream>
#include<cstdio>
#include<math.h>
using namespace std;
int main()
{
int matrix[100][100];
int t;
scanf("%d",&t);
for(int k=1;k<=t;k++)
{
int r,d;
memset(matrix,0,sizeof(matrix));
scanf("%d",&r);
for(int i=0;i<=2*r;i++)
for(int j=0;j<=2*r;j++)
{
d=(i-r)*(i-r)+(j-r)*(j-r);
if(abs(d-r*r)<=3)
matrix[i][j]=1;
}
printf("Case %d:\n",k);
for(int i=0;i<=2*r;i++)
{
for(int j=0;j<=2*r;j++)
if(matrix[i][j]==1)
printf("*");
else
printf(" ");
printf("\n");
}
}
system("pause");
return 0;
}