题目描述:
输入一个奇数n,输出一个由*构成 的n阶实心菱形。
例如输入13,打印图形如下:
分析 :
第一行是从空格开始打印,因此我们以空格的变化为主来找规律。
就拿13为例,第一行空格左右都各有6个,即n/2,之后每换一行左右各减1,到了第七行空格为0,之后空格又开始逐行左右加1,剩下的位置则是 * 的位置。
这样就不需要将上下两部分分开打印了。
代码实现:
#include<stdio.h>
int main()
{
int n;//菱形的大小
scanf("%d", &n);
int blank = n/2;//空格
int i, j;
for (i = 1; i <= n; i++)
{
for (j = 1; j <= n; j++)
{
if (j>blank && j<=n-blank)//除空格外剩下的是*
printf("*");
else
printf(" ");
}
if (i <= n / 2)
blank--;//上半部分空格逐次递减
else
blank++;//下半部分空格逐次增加
printf("\n");
}
return 0;
}