PS/백준

실버1 z(1074)

2023. 12. 31. 23:27
 

1074번: Z

한수는 크기가 2N × 2N인 2차원 배열을 Z모양으로 탐색하려고 한다. 예를 들어, 2×2배열을 왼쪽 위칸, 오른쪽 위칸, 왼쪽 아래칸, 오른쪽 아래칸 순서대로 방문하면 Z모양이다. N > 1인 경우, 배열을

www.acmicpc.net

위의 문제를 보고 분할 정복 문제라는 것을 알았지만, 분할 정복를 정확하게 모르고 있었기에 풀어내는데 조금 오래 걸렸다. 

import sys
input = sys.stdin.readline

def printResult(value, location):
  print(value + location)
  exit(0)

def divide(n, r, c, value):
  n //= 2
  if r < n and c < n:
    if n == 1: printResult(value, 0)
    divide(n, r, c, value)
  elif r < n and c >= n:
    if n == 1: printResult(value, 1)
    divide(n, r, c-n, value + (n**2 * 1))
  elif r >= n and c < n:
    if n == 1: printResult(value, 2)
    divide(n, r-n, c, value + (n**2 * 2))
  else:
    if n == 1: printResult(value, 3)
    divide(n, r-n, c-n, value + (n**2 * 3))

n, r, c = map(int,input().split())
divide(2**n,r,c,0)

입력 받은 n, r, c를 이용해서 각 사분면에 해당하면 재귀를 할 수 있게 만들었다. 이 문제는 정말 그림을 그려서 각 사분면의 숫자의 규칙성을 알아내는 것이 가장 중요했다. 그 규칙성을 빨리 찾았다면 수월하게 구현할 수 있었을 것이다.

'PS > 백준' 카테고리의 다른 글

[백준] 2583 - 영역 구하기  (0) 2024.01.11
실버2 색종이 만들기(2630)  (1) 2024.01.01
실버3 구간 합 구하기 4(11659)  (0) 2023.12.30
실버3 1로 만들기(1463)  (0) 2023.12.30
골드5 뱀과 사다리 게임(16928)  (1) 2023.12.28
'PS/백준' 카테고리의 다른 글
  • [백준] 2583 - 영역 구하기
  • 실버2 색종이 만들기(2630)
  • 실버3 구간 합 구하기 4(11659)
  • 실버3 1로 만들기(1463)
jjw000628
jjw000628
jjw000628
wldnd2
jjw000628
전체
오늘
어제
  • 분류 전체보기 (27)
    • Skill Up (1)
      • Algorithm Theory (1)
      • Java (0)
      • JS (0)
      • 프로젝트 및 회고 (0)
    • PS (23)
      • 백준 (15)
      • 프로그래머스 (8)
    • Lab (3)
      • Basic Concept (0)
      • 무선 이동 통신 (3)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 문자열
  • 그래프
  • 재귀
  • 네트워크
  • 프로그래머스
  • C++
  • JS
  • 분할정복
  • 깊이우선탐색
  • DP
  • BFS
  • 브루트포스
  • 파이썬
  • dfs
  • 백준
  • 파싱
  • Cpp
  • 누적합
  • 그래프탐색
  • 너비우선탐색
  • 무선
  • 알고리즘
  • 정규식

최근 댓글

최근 글

hELLO · Designed By 정상우.
jjw000628
실버1 z(1074)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.