#include<stdio.h>
#include<string.h>
#include<math.h>
#include<malloc.h>
//输入一个整数n,(1<=n<=20),输出一个空心菱形,其中每个边由n个'*'组成。
//输入包含一个整数,n(1<=n<=20)
//输出一个空心菱形,每个边由n个'*'组成
int main()
{
//思路:由简入繁,变成两个空心三角,估计两个for循环
//先在纸上画画,发现n=3时是个5*5的点阵,在第一行3个之前都是空格符号,在第3个是*号
//第二行往前移了一个,数目也变成2个了,只有最后一行和第一行是1个
//我们遵循先画实心的,再画空心的顺序
int n=0;
scanf("%d",&n);
for(int i=1;i<=n;i++)//上半三角行数
for(int j=1,count=0;j<=2*n-1;j++)//这么多列
{
count++;
if(i==1&&j==n+1-i)//第一行和最后一行只有一个*
{
printf("*");
}else if((i!=1||i!=n)&&(j==n+1-i||j==n+i-1))//在纸上画个图一推就出来了3阶5*5的就够了
{
printf("*");
}
else
printf(" ");
if(count==2*n-1)
{
count=0;
printf("\n");
}
}
for(int i=n-1;i>0;i--)//下半三角行数,比上半三角少一行,上面的拿过来,减一行就ok
for(int j=1,count=0;j<=2*n-1;j++)//这么多列
{
count++;
if(i==1&&j==n+1-i)//第一行和最后一行只有一个*
{
printf("*");
}else if((i!=1||i!=n)&&(j==n+1-i||j==n+i-1))
{
printf("*");
}
else
printf(" ");
if(count==2*n-1)
{
count=0;
printf("\n");
}
}
return 0;//今天又是没带return 0的一天
}
这里注意不要多打 “ ”或者*号里不要多达空格,图形会变胖,格式出错
正确的
错误格式