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