[백준] 2447번

Jeanine·2022년 3월 28일
0

baekjoon

목록 보기
42/120
post-thumbnail
post-custom-banner

💻 C++ 기반

https://www.acmicpc.net/problem/2447

✔️ base condition이 N == 3일 때 말고, N == 1일 때 코드가 더 간결할 것으로 보임

#include <iostream>

#define MAX_N 6561

using namespace std;

char ans[MAX_N][MAX_N];

void pattern(int N, int startY, int startX)
{
    for (int i = startY; i < startY + N; i++)
    {
        for (int j = startX; j < startX + N; j++)
        {
            if (i == startY + 1 && j == startX + 1)
            {
                ans[i][j] = ' ';
                continue;
            }
            ans[i][j] = '*';
        }
    }
}

void blank(int N, int startY, int startX)
{
    for (int i = startY; i < startY + N; i++)
    {
        for (int j = startX; j < startX + N; j++)
        {
            ans[i][j] = ' ';
        }
    }
}

void recur(int N, int startY, int startX)
{
    if (N == 3)
    {
        pattern(N, startY, startX);
        return;
    }

    recur(N / 3, startY, startX);
    recur(N / 3, startY, startX + N / 3);
    recur(N / 3, startY, startX + 2 * N / 3);

    recur(N / 3, startY + N / 3, startX);
    blank(N / 3, startY + N / 3, startX + N / 3);
    recur(N / 3, startY + N / 3, startX + 2 * N / 3);

    recur(N / 3, startY + 2 * N / 3, startX);
    recur(N / 3, startY + 2 * N / 3, startX + N / 3);
    recur(N / 3, startY + 2 * N / 3, startX + 2 * N / 3);
}

int main()
{
    ios_base::sync_with_stdio(false);
    cin.tie(NULL);

    int N;
    cin >> N;

    recur(N, 0, 0);

    for (int i = 0; i < N; i++)
    {
        for (int j = 0; j < N; j++)
        {
            cout << ans[i][j];
        }
        cout << '\n';
    }
    return 0;
}
profile
Grow up everyday
post-custom-banner

0개의 댓글