//把圣诞树分两个部分 三角形和枝干  难住我挺久的
//先直接定义第一个小的三角形数组;
//再把第一个复制到下面两个
//再清空第一个三角形;把1-3行的位置中间复制成刚复制下去的其中一个;
//打印枝干;
//行号 3*(2^a-1) ;
#include<stdio.h>
#include<math.h>
int main () {
    int a;
    scanf("%d", &a);
    char ch[400][800] = { "  *  ", " * * ", "* * *" };
    int i, j, k;
    int row = 3;
    int col = 5;
    for ( i = 0 ; i < a - 1 ; i++ ) { //判断需要复制几次三角形
        for ( j = 0 ; j < row ; j++ ) { //判断需要复制几行

            for ( k = 0 ; k < col ; k++ ) { //判断每行需要复制几列
                ch[j + row][k] = ch[j][k]; //第一个三角形第一行全部复制完成
                ch[j + row][k + 1 + col] = ch[j][k]; //第二个三角形第一行复制完成
            }
        }

        for (j = 0 ; j < row ; j++) { //三角形原来的位置清空
            for ( k = 0 ; k < col ; k++ ) {
                ch[j][k] = ' ';
            }
        }

        for ( j = 0 ; j < row ;
                j++) { //前面空白中间部分复制一个左下角的三角形上来
            for (k = 0 ; k < col ; k++) {
                ch[j][k + row] = ch[j + row][k];
            }
        }

        row *= 2;
        col = 2 * col + 1;
    }

    for (i = 0; i < row; i++) { //打印所有三角形
        for (j = 0; j < col; j++) {
            if(ch[i][j]=='*')
            {
                printf("%c", ch[i][j]);
            }
            else
            {
                printf(" ");
            }
            
        }
        printf("\n");
    }

    for (i = 0; i < a; i++) { //打印枝干
        for (j = 0; j < row-1 ; j++) {
            printf(" ");
        }
        printf("*\n");
    }

    return 0;
}

搜索

复制