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 |
Tags
- 메모이제이션
- 오픽노잼공부방법
- 주석
- dynamicProgramming
- English
- ㅂ
- stack 스택
- opic
- 탑다운
- 안드로이드주석
- 오픽노잼
- dp
- 안드로이드
- 오픽가격
- topdown
- fibo
- XML주석
- 바텀업
- 이진탐색
- 영어회화
- 오픽
- 오픽점수잘받는방법
- 영어말하기
- 이진탐색 #나무 자르기
- 피보나치수열
- 다이나믹프로그래밍
- 디피
- 오픽공부법
- XML
Archives
RUBY
[백준] 테트로미노 | 삼성 본문
출처:: https://www.acmicpc.net/problem/14500
분류:: 구현, 브루트 포스
1. 문제 이해 및 해결과정
- 테트로미노의 회전까지 더해서 가능한 모양은 19가지이다 - 전체 배열을 돌면서 테트로미노의 블럭이 맞는 곳 중에 최대 값을 찾는다 |
2. 풀이방법
#테트로미노
#https://www.acmicpc.net/problem/14500
import sys
sys.stdin = open("input.txt","r")
n,m=map(int,input().split())
board=[list(map(int,input().split())) for _ in range(n)]
tetromino=[ #19가지 테트로미노가 나올 수 있음
[(0,0),(0,1),(1,0),(1,1)], #ㅁ
[(0,0),(0,1),(0,2),(0,3)], #ㅡ
[(0,0),(1,0),(2,0),(3,0)], #ㅣ
[(0,0),(0,1),(0,2),(1,1)], #ㅜ
[(0,1),(1,0),(1,1),(1,2)], #ㅗ
[(0,1),(1,0),(1,1),(2,1)], #ㅓ
[(0,0),(1,0),(1,1),(2,0)], #ㅏ
[(0,0),(0,1),(0,2),(1,0)], #긴 기억 모양
[(0,2),(1,0),(1,1),(1,2)],
[(0,0),(1,0),(1,1),(1,2)],
[(0,0),(0,1),(0,2),(1,2)],
[(0,0),(0,1),(1,1),(2,1)],
[(0,0),(0,1),(1,0),(2,0)],
[(0,0),(1,0),(2,0),(2,1)],
[(0,1),(1,1),(2,0),(2,1)],
[(0,1),(1,0),(1,1),(2,0)], #번개모양
[(0,0),(1,0),(1,1),(2,1)],
[(0,1),(0,2),(1,0),(1,1)],
[(0,0),(0,1),(1,1),(1,2)]
]
res=0
def compute(h,w):
global res
for i in range(19): #테트로미노 19개
sum=0
for j in range(4): #테트로미노 블록 수
try:
nh=h+tetromino[i][j][0] #테트로미노 중 한 블록의 x좌표
nw=w+tetromino[i][j][1] #테트로미노 중 한 블록의 y좌표
sum+=board[nh][nw]
except IndexError: #테트로미노가 board밖으로 나갈 경우
continue
res=max(res,sum)
for i in range(n):
for j in range(m):
compute(i,j)
print(res)
3. 오답원인
4. 알게된 점
try, catch IndexError
try:
nh=h+tetromino[i][j][0] #테트로미노 중 한 블록의 x좌표
nw=w+tetromino[i][j][1] #테트로미노 중 한 블록의 y좌표
sum+=board[nh][nw]
except IndexError: #테트로미노가 board밖으로 나갈 경우
continue
'PS > BOJ' 카테고리의 다른 글
[백준] 치즈 (0) | 2020.09.02 |
---|---|
[백준] 미세먼지 안녕! | 삼성 (0) | 2020.08.31 |
[백준] Puyo Puyo (0) | 2020.08.28 |
[백준] 치킨배달 | 삼성 (0) | 2020.08.27 |
[백준] 인구이동 | 삼성 (0) | 2020.08.25 |
Comments