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
- 1차원 DP
- 2차원 dp
- 99클럽
- @Builder
- @GeneratedValue
- @GenericGenerator
- @NoargsConstructor
- @Transactional
- Actions
- Amazon EFS
- amazon fsx
- Android Studio
- ANSI SQL
- ApplicationEvent
- assertThat
- async/await
- AVG
- AWS
- Azure
- bind
- builder
- button
- c++
- c++ builder
- c03
- Callback
- case when
- CCW
- chat GPT
- CICD
Archives
- Today
- Total
기록
백준_14391_종이조각 본문
문제
https://www.acmicpc.net/problem/14391
풀이
1) 비트 마스킹
행렬의 각 칸은 "가로, 세로" 두가지 중 한 상태를 가질 수 있다. 예를 들어서, 아래와 같이 표현할 수 있다.
따라서, 이진수를 사용하면 16칸에 가로와 세로를 채우는 모든 경우를 쉽게 구할 수 있다.
이를 위해서 세로를 0, 가로를 1이라고 정한다.
2) 브루스포트
2진수로 만든 배열이 가지는 값을 연산한다.
위의 예시처럼 "가로" 상태를 가지는 값끼리, "세로" 값을 가지는 값끼리 묶어서 연산한다.
아래 코드에서는 문자열을 이용해서 해결했다. (아래에서 ^기호는 spacebar를 의미)
코드
N, M = map(int, input().strip().split())
board = [list(map(int, input().strip())) for i in range(N)]
vertical = '0'
horizental = '1'
# 2. 2진수 배열을 연산하기
def getScore(dirBoard) :
# horizental
string = ""
for i in range(N) :
string += " "
for j in range(M) :
if dirBoard[i][j]==horizental : string += str(board[i][j])
else : string += " "
# vertical
string += " "
for j in range(M) :
string += " "
for i in range(N) :
if dirBoard[i][j]==vertical : string += str(board[i][j])
else : string += " "
return sum(map(int, string.split()))
# 1. 2진수로 1부터 2**16까지 만들기
MAXNUM = 2**(N*M)
ans = 0
for i in range(0, MAXNUM) :
dirBoard = bin(i+MAXNUM)[3:]
# reshape (1, N*M) → (N, M)
dirBoard = [dirBoard[i:i+M] for i in range(0, M*N, M)]
ans = max(ans, getScore(dirBoard))
print(ans)
'코딩테스트 > python' 카테고리의 다른 글
백준_16724_피리 부는 사나이 (0) | 2022.10.04 |
---|---|
백준_16946_벽 부수고 이동하기4 (0) | 2022.10.03 |
백준_15661_링크와 스타트 (0) | 2022.05.03 |
백준_10830_행렬 제곱 (0) | 2022.05.03 |
백준_2961_도영이가 만든 맛있는 음식 (0) | 2022.04.22 |
Comments