今天看到了一道题。。让我想到了大一的时候,时间过的真快啊
果真还是有所成长了!!我这个家伙啊!!HHH,脑子变的灵光一点了啊
题目是这样的:
把原点用其他的符号表示出来就可以拉
最开始的时候是想用数组然后只要按照个关系填就可以拉,不过被人吐槽,喵喵喵,你tm实在浪费空间
所以换了种方法
整张图实际上可以分成四个部分,我觉得右下的算法还可以简化。。。用这种方法实际上只要知道第一个*的位置就可以把其他的都推算出来,很方便。
#include<stdio.h>
int main()
{
int i,j,k;
int x,y;
int num;
int mid;
int main()
{
int i,j,k;
int x,y;
int num;
int mid;
printf("enter odd: ");
scanf("%d",&num);
while(num%2==0)
{
printf("请输入奇数:\n");
scanf("%d",&num);
}
mid=num/2;
x=0;y=mid; //第一个符号的位置
for(i=0;i<num;i++)
{
if(i<=mid) //输出上半部分
{
scanf("%d",&num);
while(num%2==0)
{
printf("请输入奇数:\n");
scanf("%d",&num);
}
mid=num/2;
x=0;y=mid; //第一个符号的位置
for(i=0;i<num;i++)
{
if(i<=mid) //输出上半部分
{
for(j=0;j<num;j++)
{
{
if(j==mid+i || j==mid-i) //可以对照图的位置就像推算
{
printf("*");
}
else
{
printf(" ");
}
{
printf("*");
}
else
{
printf(" ");
}
}
printf("\n");
}
else if(i>mid) //输出下半部分
{
for(j=0;j<=num-2;j++)
{
if(j==i-mid || j==num-(i)+mid-1) //这里的话因为左边和右边*的位置不同所以要用不同的条件束缚
{
printf("*");
}
else
{
printf(" ");
}
}
else if(i>mid) //输出下半部分
{
for(j=0;j<=num-2;j++)
{
if(j==i-mid || j==num-(i)+mid-1) //这里的话因为左边和右边*的位置不同所以要用不同的条件束缚
{
printf("*");
}
else
{
printf(" ");
}
}
printf("\n");
printf("\n");
}
}
}
}