Description
A box fractal is defined as below :
- A box fractal of degree 1 is simply
X - A box fractal of degree 2 is
X X
X
X X - If using B(n - 1) to represent the box fractal of degree n -
1, then a box fractal of degree n is defined recursively as following
B(n - 1) B(n - 1)
B(n - 1)
B(n - 1) B(n - 1)
Your task is to draw a box fractal of degree n.
Input
Output
Sample Input
1 2 3 4 -1
Sample Output
X - X X X X X - X X X X X X X X X X X X X X X X X X X X X X X X X - X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X X -
Source
#include <iostream> #include <cstring> #include <cstdio> using namespace std; int n; char s[2200][2200]; void sett(int a,int b) { if(b > 7) { return; } for(int i = 0;i < a;i ++) { for(int j = 0;j < a;j ++) { s[i + a][j + a] = s[i + a * 2][j] = s[i][j + a * 2] = s[i + a * 2][j + a * 2] = s[i][j]; } } sett(a * 3,b + 1); } int set3(int t) { int d = 1; while(t) { d *= 3; t --; } return d; } int main() { memset(s,' ',sizeof(s)); s[0][0] = 'X'; sett(1,2); while(~scanf("%d",&n) && n != -1) { int d = set3(n - 1); for(int i = 0;i < d;i ++) { for(int j = 0;j < d;j ++) { putchar(s[i][j]); } putchar('\n'); } printf("-\n"); } }