题目:
输入描述:输入圣诞树的高度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; }