inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

세계 대회 진출자가 알려주는 코딩테스트 A to Z (with Python)

브루트 포스 알고리즘 [문제풀이] : BOJ 1342

브루토 포스 백준 1342 질문

해결된 질문

186

TAESUN

작성한 질문수 18

0

s = list(input())

n = len(s)

choose = []

check = [False] * len(s)

ans = []

def check_ad(s):

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

if s[i] == s[i+1]:

return False

return True

def make(level):

if level == n and check_ad(choose):

result = ''.join(choose)

if result not in ans:

ans.append(result)

for i in range(n):

if check[i]:

continue

choose.append(s[i])

check[i] = True

make(level + 1)

choose.pop()

check[i] = False

make(0)

print(len(ans))

 

안녕하세요 강사님! 위 코드는 시간 초과가 나는데 순열 강의 알고리즘을 그대로 사용한 것입니다! 강사님의 순열 코드는 시간 초과가 안나는데 왜 이거는 시간초과가 날까요? 내장된 permutation이 효율적으로 구현된 것일까요?

python 코딩-테스트 알고리즘

답변 2

1

알리 Ally

안녕하세요. Taejin Kim님!

공유해주신 코드를 보니, ans는 행운의 문자열을 담는 리스트로 어떤 문자열이 행운의 문자열이고 ans에 존재하지 않는다면 계속 추가하는 형식의 풀이인 걸로 확인이 됩니다.

 

element in list의 시간 복잡도는 list의 크기 만큼의 연산이 걸린다고 생각하시면 됩니다.

 

따라서 행운의 문자열의 최대 개수는 10!으로 약 360만이고, 행운의 문자열 1개를 추가할 때마다 ans에 해당 문자열의 존재 여부를 in 문법을 통해서 판단하기 때문에 최악의 경우에 1 + 2 + 3 + ... + 360만 의 연산횟수가 걸리게 됩니다. 이런 이유로 시간초과가 나게 되는 것입니다.

 

그러므로 좀 더 효율적으로 행운의 문자열의 개수를 세야 하며, 그러한 방법은 백트레킹을 이용한 풀이 또는 같은 것이 있는 순열을 이용한 풀이이며, 이는 강의를 참고해 주시면 감사하겠습니다.

 

또 궁금하신 점 있으시면 언제든 질문 부탁드립니다.

감사합니다. :)

1

TAESUN

감사합니다!

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. Taejin Kim님.

주신 코드는 입력 문자열에서 ‘행운의 문자열’을 만들기 위해 모든 가능한 순열을 조사하려는 방식으로 작성되어 있습니다. 주어진 알고리즘에서 문제가 되는 점은 check_ad 함수가 불필요하게 탐색의 모든 단계에서 중복을 검사하게 되며, 이는 비효율적입니다. 순열을 생성하고 난 후에 매번 choose 리스트의 연속된 문자가 같은지 체크하는 check_ad 함수 호출이 있기 때문에 전체적인 시간 복잡도가 크게 증가하게 됩니다.

파이썬 내장 모듈에서 제공하는 itertools.permutations는 보다 효율적으로 최적화된 C언어로 구현되어 있어서, 일반적으로 큰 데이터에 대해서도 성능이 우수합니다. 또한, 내장 함수는 중복 제거나 정렬 등의 추가 작업 없이 바로 순열 생성을 최적의 방식으로 처리합니다.

이를 해결하기 위한 방법으로는 중복 검사를 미리 수행하여 불필요한 탐색을 줄이는 것입니다. 이렇게 적절한 가지치기를 한다면, 탐색하는 경우의 수를 크게 줄여 시간 초과를 방지할 수 있습니다. 예를 들어, 이미 선택한 문자가 마지막 선택한 문자와 동일하다면 그 상태에서는 추가적으로 탐색을 하지 않도록 가지치기를 할 수 있습니다.

관련된 기존 답변을 참고하고 싶다면 여기의 답변도 확인해 보세요. 유사한 백트래킹 문제에 관한 답변과 성능 최적화를 위한 가이드라인을 제공하고 있습니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.

현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

Iterable 관련 설명 중 의문점

1

73

1

DP 알고리즘 index 0 이유?

0

80

2

백준에서 queue.PriorityQueue() 사용 시 런타임에러가 납니다.

0

78

2

(시간 초과) BOJ 1342 관련하여 질문이 있습니다

1

79

2

BFS, DFS

0

105

2

이중연결리스트에 관한 수업 내용도 있을까요?

0

98

1

영상에서 설명이 잘못됐고 자막이 맞는 내용이라고 자막에 표기

0

113

2

최대값 int(1e6, 1e7, 1e8) 기준

0

272

2

섹션 3 BOJ 1342 //= 연산자 관련

0

87

3

라이브러리 사용

0

118

2

2번 구현 방법 질문 있습니다.

0

167

1

브루트 포스 풀이

0

144

2

다익스트라 음수 간선

0

159

1

종료 조건

0

117

2

BOJ 1342 메모리초과 관련

0

123

2

진짜 엄청나네요. 이 가격에 새로운 컨텐츠 추가라니

0

215

1

섹션3 브루트포스 알고리즘 1342 풀이1 질문

0

151

2

boj 3020

0

127

1

강의 내용 중 백트래킹 존재 여부

0

156

1

제가 공부하는 방법이 괜찮은지 궁금합니다

1

261

2

DP 11053관련 질문있습니다.

0

120

1

17609 투포인터 문제를 재귀로 풀 경우가 궁금합니다!

0

138

3

3020번 풀이 코드관련 질문있어요

0

171

2

재귀 관련 문제 관찰할 때 질문

0

197

1