//把圣诞树分两个部分 三角形和枝干 难住我挺久的
//先直接定义第一个小的三角形数组;
//再把第一个复制到下面两个
//再清空第一个三角形;把1-3行的位置中间复制成刚复制下去的其中一个;
//打印枝干;
//行号 3*(2^a-1) ;
#include<stdio.h>
#include<math.h>
int main () {
int a;
scanf("%d", &a);
char ch[400][800] = { " * ", " * * ", "* * *" };
int i, j, k;
int row = 3;
int col = 5;
for ( i = 0 ; i < a - 1 ; i++ ) { //判断需要复制几次三角形
for ( j = 0 ; j < row ; j++ ) { //判断需要复制几行
for ( k = 0 ; k < col ; k++ ) { //判断每行需要复制几列
ch[j + row][k] = ch[j][k]; //第一个三角形第一行全部复制完成
ch[j + row][k + 1 + col] = ch[j][k]; //第二个三角形第一行复制完成
}
}
for (j = 0 ; j < row ; j++) { //三角形原来的位置清空
for ( k = 0 ; k < col ; k++ ) {
ch[j][k] = ' ';
}
}
for ( j = 0 ; j < row ;
j++) { //前面空白中间部分复制一个左下角的三角形上来
for (k = 0 ; k < col ; k++) {
ch[j][k + row] = ch[j + row][k];
}
}
row *= 2;
col = 2 * col + 1;
}
for (i = 0; i < row; i++) { //打印所有三角形
for (j = 0; j < col; j++) {
if(ch[i][j]=='*')
{
printf("%c", ch[i][j]);
}
else
{
printf(" ");
}
}
printf("\n");
}
for (i = 0; i < a; i++) { //打印枝干
for (j = 0; j < row-1 ; j++) {
printf(" ");
}
printf("*\n");
}
return 0;
}
搜索
复制

京公网安备 11010502036488号