본문 바로가기

메모장/백준 온라인 저지(BOJ)

백준 1343번 - 폴리오미노

 

https://www.acmicpc.net/problem/1343

 

 

 

 문제

민식이는 다음과 같은 폴리오미노 2개를 무한개만큼 가지고 있다. AAAA와 BB
이제 '.'와 'X'로 이루어진 보드판이 주어졌을 때, 민식이는 겹침없이 'X'를 모두 폴리오미노로 덮으려고 한다. 이때, '.'는 폴리오미노로 덮으면 안 된다.
폴리오미노로 모두 덮은 보드판을 출력하는 프로그램을 작성하시오.

 입력

첫째 줄에 보드판이 주어진다. 보드판의 크기는 최대 50이다.

 출력

첫째 줄에 사전순으로 가장 앞서는 답을 출력한다. 만약 덮을 수 없으면 -1을 출력한다.

 예제 입력 1

XXXXXX

 예제 출력 1

AAAABB

예제 입력 2

XX.XX

 예제 출력 2

BB.BB

예제 입력 3

XXXX....XXX.....XX

 예제 출력 3

-1

예제 입력 4

X

 예제 출력 4

-1

예제 입력 5

XX.XXXXXXXXXX..XXXXXXXX...XXXXXX

 예제 출력 5

BB.AAAAAAAABB..AAAAAAAA...AAAABB

Solution


Python

# ver.1

board = input()
cnt,pre = 0,-1
result = ''

for _ in range(len(board)):
  idx = board[pre+1:].find('.')
  if idx == -1:
    idx = len(board[pre+1:])

  temp = idx
  if temp % 2 == 0:
    result += 'AAAA' * (temp // 4)
    temp %= 4
    result += 'BB' * (temp // 2)
  else:
    result = '-1'
    break

  if idx == len(board[pre+1:]):
    break
  else:
    result += '.'
  pre += idx+1

print(result)
# ver.2

board = list(map(str, input().split('.')))
result = ''

for i in board:
  temp = len(i)
  if temp % 2 == 0:
    result += 'AAAA' * (temp // 4)
    temp %= 4
    result += 'BB' * (temp // 2)
    result += '.'
  else:
    result = '-1 '
    break

print(result[:-1])