알고리즘

파이썬) 문자열 교환 - BOJ

1일1공부실천하자 2023. 12. 3. 21:05

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

 

s = input()  # 문자열 입력
a = s.count('a')  # 입력된 str에서의 a의 개수

answer = float('inf')


s = s + s[0:a-1]


for i in range(len(s) - (a-1)):

    answer = min(answer, s[i:i+a].count('b'))

print(answer)

 

문제는 연속된 b를 만들기 위해 몇 번의 교환을 해야할까?를 묻는 문제다.

바꿔말하면 문자열 s중 0번 부터 a의 개수만큼까지는 a로 가득 채워져있어야한다는 뜻이다. 이를 잘 기억해서 다음과 같이 풀어보자.

문자열이

abababababababa

라고 생각해보자.

a의 개수는 8이다.

즉 aaaaaaaabbbbbbb가 되어야 연속된 b를 만들 수 있다.

(abababab)abababa 괄호를 친 만큼은 a로 연속되어야 있어야하니, 저 괄호 안에 있는 b는 괄호 밖에 있는 a와 교환되어야한다.

하지만 인덱스 0번부터 7번까지만 확인하면 최소 교환수를 알 수가 없다. 그러므로 반복문으로 i부터 i+8만큼 슬라이싱하여 b의 개수를 확인해야한다.

(abababab)abababa
a(babababa)bababa
ab(abababab)ababa
.
.
.

 

주의할 점은 이 문자열 s는 원형이기에 끝과 끝이 이어져있다는 것이다.

즉, 우리는 s의 마지막에서 s의 0번부터 a-1만큼 s에 더해주어야한다.

이를 잘 생각하며 코드를 짜면 문제없이 풀어낼 수 있다.