Algorithm
(BOJ) 2447 풀이
snwo
2022. 2. 24. 20:13
#include<bits/stdc++.h>
using namespace std;
char sqare[2188][2188];
void make(int n,int x,int y){
if(n==1){
sqare[x][y]='*';
return;
}
for(int i=0;i<3;i++){
for(int j=0;j<3;j++){
if(i==1&&j==1)
continue;
make(n/3,n/3*i+x,n/3*j+y);
}
}
}
int main(void){
ios::sync_with_stdio(0);cin.tie(0);
int N;
cin >> N;
for(int i=0;i<N;i++){
fill(&sqare[i][0],&sqare[i][N],' ');
}
make(N,0,0);
for(int i=0;i<N;i++){
cout << sqare[i] << '\n';
}
}
// 3
// ***
// * *
// ***
// 9
// *********
// * ** ** *
// *********
// *** ***
// * * * *
// *** ***
// *********
// * ** ** *
// *********
함수원형
void func(int n,int x,in y)
n : 현재 구역 크기
x : 행
y : 열
base condition
n==1 일 때, ar[x][y]=’*’
재귀식
반복문을 3x3 형태로 돌면서 가운데를 제외하고 좌표를 구해 재귀함수를 호출한다.
좌표는 n/3*(i or j) + (x or y)
으로 구할 수 있다.