题解 | #圣诞树#
圣诞树
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决定。