空心菱形,是我OJ题中遇到的较为麻烦的一道题。初做时思路较为凌乱,便先空着,转眼将近一个个月过去,整合平日里的思路,便得以下ji故此便做出文章,来记录这时的思路,以便后续遇到空心三角形、矩形、甚至较为复杂的图案以提供思路。也希望能帮助到屏幕前的你。
#include<stdio.h>
int main()
{
int n,k,i,j=-1,j1,p,p1;//这里的k是为了输出整体空心菱形的左半边 ,j、j1是为了输出右上空心菱形的右半边
//p、p1是为了输出空心菱形的右下部分
scanf("%d",&n);
for(i=1;i<=n;i++,j=j+2)
{
k=n-i;
while(k>0)//此步骤可以输出第i行的第一个'*'号前的k个空格
{
k--;
printf(" ");
}
printf("*");//不能有'\n',以便第二个星号紧随其后
j1=j;//将j的值赋值给j1的原因是j要参与for循环
//我们可以发现,第二行的两个星号之间有一个空格,第三行有三个空格(两星号之间的空格呈等差数列)...以此类推,
//所以让j=-1的目的是既可以避免多输出第一行的星号,又可以输出第i(i>1)行两星号之间的j个空格
while(j1>0)//避免多输出第一行的星号
{
while(j1>0)//输出两星号之间的空格
{
j1--;
printf(" ");
}
printf("*");
}
printf("\n");//输出一行星号之后,换行
}
p=j-4;//以便输出下半部分两星号之间的空格
for(i=n-1;i>=1;i--,p=p-2)
{
k=n-i;
while(k>0)
{
k--;
printf(" ");
}
printf("*");
p1=p;
while(p1>0)//同上,避免最后多输出一个星号
{
while(p1>0)
{
p1--;
printf(" ");
}
printf("*");
}
printf("\n");
}
return 0;
}