题解 | #圣诞树#

圣诞树

https://www.nowcoder.com/practice/9a03096ed8ab449e9b10b0466de29eb2

#include <stdio.h>

int main() {
    int n;
    scanf("%d",&n);
    for(int i=1;i<=3*n;i++)
    {
        for(int k=1;k<=3*n-i;k++)
            printf(" ");//确定点的最初位置
        for(int m=1;m<=(i+2)/3;m++)//确定画几个块
        {
            if(i%3==1)
            printf("*     ");
             else if(i%3==2)
             printf("* *   "); 
             else 
             printf("* * * ");
        }
        puts("");
        }
    for(int i=1;i<=n;i++)//尾巴
    {
        for(int m=1;m<=3*n-1;m++)
        printf(" ");
        puts("*");
    }
}

行数为3*n,最外层循环控制树冠行数,首先确定第一个点的位置,即每行最开始有几个空格,打印完空格后第一个点的位置就确定了,每三行有一个完整的三角形,i%3的结果决定是小三角形的第几行,而每行三角形一部分的个数(i+2)/3决定。

全部评论

相关推荐

点赞 评论 收藏
转发
1 收藏 评论
分享
牛客网
牛客企业服务