题目描述
输出双层金字塔。
输入描述:
多个测试数据。每个测试数据输入一个整数n( 2 <= n <= 9)
输出描述:
输出双层金字塔
示例1
输入
2
5
输出
金字塔题目一直是比较头疼的,总是觉得复杂。。
但是仔细分析不是很难,就是得找到每次输入的*和空格的数量规律
int main(){
int n; //总共有2n-1行
while(scanf("%d",&n) != EOF){ //多组输入的固定套路
for(int i=1;i<=2*n-1;i++){
for(int j=i;j<=n-1;j++){ //此处只对第1行到*最多的那一行有用
printf(" ");
}
if(i<=n){ //此处只对第1行到*最多的那一行有用,剩下的行放到else中
for(int k=1;k<=2*i-1;k++){
printf("*");
}
printf("\n");
}
else{
for(int j=i;j>= n+1;j--){ //若n=5,第6行有7个*1个空格,可令j>=(5+1)6,j--来实现空格数量
printf(" ");
}
for(int k=1;k<=2*(2*n-i) -1 ;k++){ //第6行7个*可看成2*4-1 == 2*(2*5-6)-1
printf("*");
}
printf("\n");
}
}
}
return 0;
}