배열 한 변의 길이는 2^N
한 변이 2^(N-1)인 사각형 4개로 나누어
왼쪽 위 - 오른쪽 위 - 왼쪽 아래 - 오른쪽 아래 순서
한 변의 길이가 2가 되었을 때 static int number 를 대입하면 됨
이후 board[r][c]의 값을 출력하면 된다
-> 메모리 초과 발생
board 전체를 recursion() 해서 그런 것으로 생각된다
r, c의 위치를 계속 추척해, 해당하는 영역만 recursion 할 필요가 있다
-> number++이 덜 실행되어 당연히 훨씬 작은 값이 나왔다
number 값을 미리 올려 주면 해결된다
- newSize = size/2
- 1사분면 :
- 2사분면 : number += Math.pow(2, newSize)
- 3사분면 : number += Math.pow(2, newSize)*2
- 4사분면 : number += Math.pow(2, newSize)*3
최종 size 도 2 대신 1로 수정했다
-> 계속 메모리 초과 떠서 확인하니 board 를 계속 사용중이었다
어차피 위와 같이 number 값을 업데이트하면 board[r][c]의 값이 되어있음
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.StringTokenizer;
public class Main {
static int N;
static int r;
static int c;
static int number = 0;
static void recursion(int startRow, int startColumn, int size){
if(size==1){
return;
}else{
int newSize = size/2;
if(startRow<=r && r<startRow+newSize && startColumn<=c && c<startColumn+newSize) {
recursion(startRow, startColumn, newSize);
}else if(startRow<=r && r<startRow+newSize && startColumn+newSize<=c && c<startColumn+size){
number += (int)Math.pow(newSize, 2);
recursion(startRow, startColumn+newSize, newSize);
}else if(startRow+newSize<=r && r<startRow+size && startColumn<=c && c<startColumn+newSize){
number += (int)Math.pow(newSize, 2)*2;
recursion(startRow+newSize, startColumn, newSize);
}else if(startRow+newSize<=r && r<startRow+size && startColumn+newSize<=c && c<startColumn+size){
number += (int)Math.pow(newSize, 2)*3;
recursion(startRow+newSize, startColumn+newSize, newSize);
}
}
}
public static void main(String[] args) throws IOException {
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
StringTokenizer stk = new StringTokenizer(br.readLine());
int n = Integer.parseInt(stk.nextToken());
N = (int)Math.pow(2, n);
r = Integer.parseInt(stk.nextToken());
c = Integer.parseInt(stk.nextToken());
recursion(0, 0, N);
System.out.println(number);
}
}
'[Solved] > BOJ' 카테고리의 다른 글
[백준 2630] 색종이 만들기 (0) | 2023.05.14 |
---|---|
[백준 2448] 별 찍기 - 11 (0) | 2023.05.13 |
[백준 17136] 외판원 순회 (0) | 2023.05.07 |
[백준 16987] 계란으로 계란치기 (0) | 2023.05.06 |
[백준 9663] N-Queen (0) | 2023.05.05 |