1216.[S/W 문제해결 기본] 3일차 - 회문2

풀이

def is_pal(word):
    
    check = 1
    while word:
        if word[0] != word[-1]:
            check = 0
            break
        word = word[1:-1]
    if check:
        return True
    return False


# T = int(input())
T = 10

answer = []
for tc in range(1, T + 1):

    nothing = int(input())
    
    board = []
    for _ in range(100):
        board.append(input())

    result = 0
    for i in range(100):
        for j in range(100):
            length = 1
            k = 1
            while j+k < 100:
                if board[i][j+k] == board[i][j]:
                    if is_pal(board[i][j:j+k+1]):
                        if length < k+1:
                            length = k+1
                k += 1

            if result < length:
                result = length

            k = 1
            length = 1
            while i+k < 100:
                if board[i+k][j] == board[i][j]:
                    word = ''
                    for x in range(i, i+k+1):
                        word += board[x][j]
                    if is_pal(word):
                        if length < k+1:
                            length = k+1
                k += 1

            if result < length:
                result = length
                

    answer.append(result)    

for tc in range(1, T+1):
    print(f'#{tc} {answer[tc-1]}')