Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- programmers
- 백준
- Interview Preparation Kit
- 파이썬
- 격파르타 장점
- 머신러닝
- 야근지수
- Roads and Libraries
- 격파르타 합격후기
- Algorithm
- DFS: Connected Cell in a Grid
- hackerrank
- 격파르타 후기
- Reverse Shuffle Merge
- Max Array Sum
- Common Child
- 피보나치 함수
- 구슬탈출2
- 해커랭크
- BFS: Shortest Reach in a Graph
- 프로그래머스
- Recursion: Davis' Staircase
- python
- Find the nearest clone
- 알고리즘
- Special String Again
- [sqld]자격증합격
- candies
- 매칭점수
- 코딩테스트
Archives
- Today
- Total
Archive
[BOJ] 12100번. 2048(Easy) 본문
풀이
- DFS를 사용하는 문제
- 모든 경우의수를 다 시도해봄.
- max_val, board를 글로벌 변수로 두고 사용.
- 해당 위치에서 숫자가 바뀌었는지 안바뀌었는지 정보도 저장해야함.
- 4, 4, 4, 4 -> 오른쪽으로 -> 0, 0, 8, 8이 되어야함 (cf. 0, 0, 8, 8에서 0, 0, 0, 16이 되면 안됨.)
# 입력 받음
n = int(input())
board = [list(map(int, input().split())) for _ in range(n)]
# 방향 배열 : 위, 오른쪽, 아래, 왼쪽
dx = [-1, 0, 1, 0]
dy = [0, 1, 0, -1]
max_val, count = -1, 0
def move(board, dir):
if dir == 0 or dir == 3:
start_idx, end_idx, diff = 0, n, 1
else:
start_idx, end_idx, diff = n-1, -1, -1
ch = [[1 for _ in range(n)] for _ in range(n)]
for i in range(start_idx, end_idx, diff):
for j in range(start_idx, end_idx, diff):
if board[i][j] == 0:
continue
x, y = i, j
# 다음칸 좌표
next_x = i + dx[dir]
next_y = j + dy[dir]
# 현재 좌표는 다로 저장하고, 0으로 바꿔줌
val = board[i][j]
board[i][j] = 0
while 0 <= next_x <= n-1 and 0 <= next_y <= n-1:
# 보드의 다음 좌표값이 0이면 계속 이동
if board[next_x][next_y] == 0:
x, y = next_x, next_y
next_x, next_y = next_x + dx[dir], next_y + dy[dir]
# 다음 칸의 블록 숫자와 기존 블록 숫자가 같음. 그리고 다음 칸에서 숫자바뀜이 안일어났는지 확인.(중복체크)
elif board[next_x][next_y] == val and ch[next_x][next_y]:
ch[next_x][next_y] = 0
x, y = next_x, next_y
break
else:
break
board[x][y] = board[x][y] + val
return board
def DFS(count):
global max_val, board
# 5번째가 됬을때 max_val 업데이트함.
if count == 5:
max_val = max(max_val, max([max(i) for i in board]))
else:
for i in range(4):
b = [x[:] for x in board]
board = move(board, i)
DFS(count + 1)
board = [x[:] for x in b]
DFS(0)
print(max_val)
'공부 > Algorithm' 카테고리의 다른 글
[BOJ] 13460번. 구슬탈출2 (0) | 2021.02.21 |
---|---|
[BOJ] 1003. 피보나치 함수 (0) | 2021.02.14 |
[BOJ] 10451. 순열 사이클 (0) | 2021.02.14 |
[BOJ] 2178. 미로탐색 (0) | 2021.02.07 |
[BOJ] 1303. 전쟁-전투 (0) | 2021.02.07 |
Comments