int main()
{
int input = 0;
scanf("%d", &input);
int i = 0;
for (i = 0; i < input; i++) 打印上半部分
{
int j = 0;
for (j = 0; j < input - 1-i; j++) 打印行 等差数列
{
printf(" ");
}
for (j = 0; j < 2 * i + 1; j++) 打印列 等差数列
{
printf("*");
}
printf("\n");
}
int j = 0;
for (i = 0; i < input - 1; i++) 打印下半部分
{
for (j = 0; j <= i; j++) 打印行
{
printf(" ");
}
for (j = 0; j < 2 * (input - i - 1) - 1; j++) 打印列 等差数列
{
printf("*");
}
printf("\n");
}
return 0;
}
先打印上半部分
行是空格,列是*
先打印循环次数,包括最中间那行。
空格从上到下,构成一个等差数列
n-i-1,i为第几行。
* 从左到右,* 从上到下,每行构成一个等差数列,2×(n-i)
上半部分,先打印行,再打印列,空格完之后,跟上列*,再打印换行
打印下半部分
空格行和列*一样是等差数列,只不过是和上半部分反过来
先打印循环次数,从中间的行开始,下一行为0行,打印六行,用for循环
用列和行的比较关系,打印空格,i=0,j<=i,0的时候也可以打打印一次空格,i为1打印2次,接着累加,每次for循环完空格,打印列*,等差数列2×(n-i-1)-1,再输出换行