题目描述

输出双层金字塔。

输入描述:

多个测试数据。每个测试数据输入一个整数n( 2 <= n <= 9)

输出描述:

输出双层金字塔

示例1

输入

2

5

输出

alt

金字塔题目一直是比较头疼的,总是觉得复杂。。

但是仔细分析不是很难,就是得找到每次输入的*和空格的数量规律

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;
}