题解 | #圣诞树#

圣诞树

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决定。

全部评论

相关推荐

09-25 00:00
已编辑
电子科技大学 Java
球球与墩墩:这不是前端常考的对象扁平化吗,面试官像是前端出来的 const flattern = (obj) => { const res = {}; const dfs = (curr, path) => { if(typeof curr === 'object' && curr !== null) { const isArray = Array.isArray(curr); for(let key in curr) { const newPath = path ? isArray ? `${path}[${key}]` : `${path}.${key}` : key; dfs(curr[key], newPath); } } else { res[path] = curr } } dfs(obj); return res; }
查看3道真题和解析
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务