如左图为一个边长为5的空心*型菱形。
解题思路:
观察图形,拆分成每一行来看。第一行和最后一行是比较特殊的(只有一个*),其余部分每行都有两个*,然而这一部分又可以分为两个部分,正梯形部分和倒梯形部分(需要注意的是导梯形部分少了一行,因为菱形的行数为奇数,除去顶部和底部,还是一个奇数行,无法做到平分,故而我将这一行正梯形部分)。
代码:
#include <stdio.h>
int main(){
int n,i,m=1; //i记录行数,m控制两*之间空格的个数
printf("请输入边长n(大于1):");
scanf("%d",&n);
printf("%*s*",n-1,""); //输出第一行*(第一个*表示占位符,用来输出n-1个"(空格)"
printf("\n");
//打印正金字塔
for(i=2;i<=n;i++,m+=2){
printf("%*s*%*s*",n-i,"",m,""); //空格,*号个数控制部分
printf("\n");
}
//打印倒金字塔
for(i=n,m=m-4;i>2;i--,m-=2){
printf("%*s*%*s*",n-i+1,"",m,"");
printf("\n");
}
printf("%*s*",n-1,"",n,"" ); //输出最后一行*
return 0;
}