[BOJ / C++] Z (재귀)

2025. 7. 11. 14:51·코딩테스트/BOJ

문제링크: https://www.acmicpc.net/problem/1074

 

1. 코드

#include <bits/stdc++.h>
using namespace std;

int func(int n, int r, int c) {
	if (n == 0) return 0;

	int center = (1<<n) / 2;

	if (r < center && c < center) return func(n-1, r, c);
	else if (r < center && c >= center) return center*center + func(n-1, r, c-center);
	else if (r >= center && c < center) return 2*center*center + func(n-1, r-center, c);
	else if (r >= center && c >= center) return 3*center*center + func(n-1, r-center, c-center);
}

int main() {
	ios::sync_with_stdio(0); cin.tie(0);

	int n, r, c;
	cin >> n >> r >> c;

	cout << func(n, r, c);
}

 

2. 분석

n=3일때 Z

n=3일 때 가로, 세로는 2^3=8이고 center 4를 기준으로 4등분 할 수 있다. 4등분 했을 때 좌상부가 기준이 되고, 순서대로 우상부는 center*center + 좌상부에 대응된다. 좌하부는 2*center*center에 대응되고, 우하부는 3*center*center에 대응된다. 이를 재귀식으로 잘 분리해서 호출해주면 된다.

 

3. 시간복잡도

재귀 호출을 이용했고, 재귀의 깊이는 n에 비례한다. 각각에서 재귀호출은 한번씩만 일어나므로 총 n번 호출이 일어나고 시간복잡도는 O(n)이다. 

 

 

 

'코딩테스트 > BOJ' 카테고리의 다른 글

[BOJ / C++] 상범 빌딩 (BFS)  (0) 2025.07.13
[BOJ / C++] 불 (BFS)  (0) 2025.07.13
[BOJ / C++] 하노이 탑 이동 순서 (재귀)  (0) 2025.07.10
[BOJ / C++] 곱셈 (재귀)  (0) 2025.07.09
[BOJ / C++] 안전 영역 (BFS)  (0) 2025.07.08
'코딩테스트/BOJ' 카테고리의 다른 글
  • [BOJ / C++] 상범 빌딩 (BFS)
  • [BOJ / C++] 불 (BFS)
  • [BOJ / C++] 하노이 탑 이동 순서 (재귀)
  • [BOJ / C++] 곱셈 (재귀)
sophon
sophon
sophon 님의 블로그 입니다.
  • sophon
    sophon 님의 블로그
    sophon
    • 카테고리 (172) N
      • 컴퓨터공학 (36)
        • 데이터베이스 (19)
        • 네트워크 (15)
        • 기타 이슈 (2)
      • 프로젝트 (16)
        • Java (8)
        • Spring (4)
        • Docker (4)
      • 코딩테스트 (95) N
        • BOJ (74)
        • 프로그래머스 (7)
        • 프로그래머스 SQL (12) N
        • PS Snippets (2)
      • 🌱 잡담 (22)
        • 자격증 (7)
        • 좋은 시 모음 (12)
        • 책과 영화 (3)
        • 기록 (0)
  • 전체
    오늘
    어제
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 최근 글

  • hELLO· Designed By정상우.v4.10.6
sophon
[BOJ / C++] Z (재귀)
상단으로

티스토리툴바