记录编号 605439 评测结果 A
题目名称 1332.[POJ 2083]分形 最终得分 100
用户昵称 Gravatar李奇文 是否通过 通过
代码语言 C++ 运行时间 0.449 s
提交时间 2025-09-01 11:38:16 内存使用 4.02 MiB
显示代码纯文本
#include<bits/stdc++.h>
using namespace std;
const int N=730;
char d[N][N];
int n;
void dfs(int x,int y,int n){
    if(n==1){
        d[x][y]='X';
    }else{
        int m=pow(3,n-2);
        dfs(x,y,n-1);
        dfs(x+2*m,y,n-1);
        dfs(x,y+2*m,n-1);
        dfs(x+m,y+m,n-1);
        dfs(x+2*m,y+2*m,n-1);
    }
}
int main(){
    for(int i=0;i<N;i++){
        for(int j=0;j<N;j++){
            d[i][j]=' ';
        }
    }
    dfs(0,0,7);
    while(cin>>n,n!=-1){
        int len=pow(3,n-1);
        for(int i=0;i<len;i++){
            for(int j=0;j<len;j++){
                cout<<d[i][j];
            }
            cout<<endl;
        }
        cout<<"-"<<endl;
    }
    return 0;
}