题目:
输入描述:输入圣诞树的高度h,1<= h <= 1001<=h<=100
输出描述:输出对应的圣诞树:
输入:1 输入:2 输入:3
输出: 输出: 输出:
对比三个图,可以发现高度1有1个,高度2有2个,高度3有3个,我们以一个三角形为单位,可以发现:
当输入2时,因为三角形有3个,所以高度1前都有3个空格;
输入为3时,高度为1时,有6个空格;高度为2时,则3个空格;高度为3时,空格为0;
结论,一共有多少个三角形,第一行前面就有多少个空格(不包括1),随着深度的相加对应减少三个空格。
每一次打印一个红框内的内容(包括空格):空格 空格 *空格 空格 空格 空格 * 空格 * 空格 空格 * 空格 * 空格 * 空格
代码如下:
#include<stdio.h>
int main(){
int n, l, p = 0;
scanf("%d", &n);
for(int i = 0; i < 3 * n; i++){
l = i / 3 + 1; //当前所在层,三行一层,在第几层就打印几个三角;
for(int j = 0; j < n - l; j++){ //空格数 = 层数 * 3
printf(" ");
}
for(int k = 0; k < l; k++){
p = i % 3; //在三角形的第几行
if(!p)
printf(" * ");
else if (p == 1)
printf(" * * ");
else
printf("* * * ");
}
printf("\n");
}
for(int i = 0; i < n; i++){
for(int j = 0; j < 3 * n; j++){
if(j == 3 * n - 1)
printf("*\n");
else
printf(" ");
}
}
return 0;
}