시냅스

백준 boj 3085 - 사탕 게임 (파이썬, python) 본문

알고리즘

백준 boj 3085 - 사탕 게임 (파이썬, python)

ted k 2022. 2. 9. 20:55

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

 

3085번: 사탕 게임

예제 3의 경우 4번 행의 Y와 C를 바꾸면 사탕 네 개를 먹을 수 있다.

www.acmicpc.net

 

브루트포스를 활용하여 문제를 해결하였다.

 

문제 제한 시간이 1초라 시간초과에 유의했으나,

애초에 입력값이 작아 o(n^4) 되는 나의 솔루션도 문제가 없는 것 같다.

 

풀이는 입력값을 받은 배열에 있는 모든 원소를

가로로 한 번 교체하여 최대값을 확인하고,

세로로 한 번 교체하여 최대값을 확인하였다.

다만 교체한 후에는 원상복귀하여 배열에 이상이 없게 해야했다. 

그렇게 도출된 cnt와 result를 비교하여 더 큰 값을 결과값으로 도출하였다.

 

파이썬의 스왑은 언제나 감동적이다...

 

code

 

n = int(input())
result = 0
bombo = [list(input()) for _ in range(n)]

def check_bombo():
    global result
    for i in range(n): # 가로 맥스 카운팅
        cnt = 1
        for j in range(n - 1):
            if bombo[i][j] == bombo[i][j + 1]:
                cnt += 1
                result = max(result, cnt)
            else:
                cnt = 1

    for i in range(n): # 세로 맥스 카운팅
        cnt = 1
        for j in range(n - 1):
            if bombo[j][i] == bombo[j + 1][i]:
                cnt += 1
                result = max(result, cnt)
            else:
                cnt = 1

for i in range(n):
    for j in range(n - 1):
            bombo[i][j], bombo[i][j + 1] = bombo[i][j + 1], bombo[i][j] # 가로 교체
            check_bombo()
            bombo[i][j + 1], bombo[i][j] = bombo[i][j], bombo[i][j + 1] # 원복

            bombo[j][i], bombo[j + 1][i] = bombo[j + 1][i], bombo[j][i] # 세로 교체
            check_bombo()
            bombo[j + 1][i], bombo[j][i] = bombo[j][i], bombo[j + 1][i] # 원복
print(result)
Comments