题目
解题思路:
假设 x是菱形中间的那一层 x = n/2 +1;
每一层左边的空格个数与他在层数和 x层有联系
设 当层数 i=1; x=4 从左到右 需要输出 x-i * 2个空格 这样能恰好到指定位置输出
一直对 第x层 把x层输出完后 就到 x-1层
这时候处理完了 从上至下 第一层-x层
我们接下来处理下半部分
使i=1 i<x; i++ 次循环;
在通过每层 用i*2在-1 使其层数从x-1 到0;
代码
#include<stdio.h>
#include<stdlib.h>
void PrintDiamond();
int main()
{
PrintDiamond();
return 0;
}
void PrintDiamond()
{
int n;
scanf("%d", &n); // 读取整数n ;
int x = (n/2)+1;
for(int i=1; i<=x; i++)
{
for(int k = x-i; k>0; k--)
{
printf(" ");
}
for( int j=0; j<(i*2-1); j++)
{
printf("* ");
}
printf("\n");
}
for( int i=1; i<x; i++)
{
for(int k=0; k<i; k++)
{
printf(" ");
}
for( int j=(x-i)*2-1; j>0; j--)
{
printf("* ");
}
printf("\n");
}
}