题解 | #超级圣诞树# 递归

超级圣诞树

http://www.nowcoder.com/practice/470d26c9a73e4e17be8cc45cac843423

先按规律处理好,放进ans数组,再把右侧多余的空格干掉。

n = int(input())
def copy(ans,tmp,sx,sy):
    for i in range(sx,sx+len(tmp)):
        ans[i][sy:sy+len(tmp[0])] = tmp[i-sx][:]
def solve(dep):
    if dep == 1:
        return [
            [0,0,1,0,0],
            [0,1,0,1,0],
            [1,0,1,0,1],
        ]
    tmp = solve(dep-1)
    ans = [[0] * (2*len(tmp[0])+1) for i in range(2*len(tmp))]
    copy(ans,tmp,0,1 + (len(tmp[0]) >> 1))
    copy(ans,tmp,len(tmp),0)
    copy(ans,tmp,len(tmp),1 + len(tmp[0]))
    return ans
ans = solve(n)
for i,line in enumerate(ans):
    line.reverse()
    line = line[line.index(1):]
    line.reverse()
    ans[i] = ''.join([' ' if not v else '*' for v in line])
ans.extend([' ' * (len(ans[-1])>>1) + '*'] * n)
for line in ans: print(line)
全部评论

相关推荐

昨天 17:22
已编辑
西安交通大学 Java
华为 昇腾 ai软件开发 薪资20k x (14-16),职级13A,5%公积金,c/cpp
BLOOMING7:闭眼滴滴,华子给的又少又累
点赞 评论 收藏
分享
牛客717484937号:双飞硕没实习挺要命的
点赞 评论 收藏
分享
10-09 22:05
666 C++
找到工作就狠狠玩CSGO:报联合国演讲,报电子烟设计与制造
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-27 10:46
点赞 评论 收藏
分享
评论
6
收藏
分享
牛客网
牛客企业服务