섹션3 브루트포스 알고리즘 1342 풀이1 질문
섹션3 브루트포스 알고리즘 1342 문제 풀이 강의에서
풀이1 질문이 있습니다.
for i in range(ord('a'), ord('z') + 1) :
ans //= fact(S.count(chr(i)))
이렇게 fact로 나눠주라고 하셨는데,
왜 나눠주는 지 이해가 잘 안됩니다.
같은 문자가 있을 때 나눠주는 건 알고있습니다.
근데 그건 경우의 수를 구할 때고,
이건 인접한 문자가 같은 지 아닌 지를 구하는 건데
왜 나눠줘야 하나요?
回答 2
0
안녕하세요, kimgguggury1002님!
인접한 문자가 같은 지 아닌 지를 구하는 부분은 아래의 코드입니다.
for perm in permutations(S):
ok = True
for i in range(0, len(S) - 1):
if perm[i] == perm[i + 1]:
ok = False
break
ans += ok
위의 과정을 거치면 ans는 중복된 문자열을 고려하지 않고 문제의 조건을 만족하는 문자열의 개수가 담겨 있습니다. 중복된 문자열을 고려하지 않고 경우의 수를 구했으니 중복된 문자열을 고려해야 하며, 이를 처리하는 부분이 질문자님께서 올려주신 코드 부분입니다.
중복된 문자열을 고려하여 처리하는 방법은 같은 것이 있는 순열의 개념을 이용하면 되며, 이러한 내용은 해당 강의의 2:10 - 4:02 부분에서 설명하고 있으니 참고하시면 될 것 같습니다!
질문에 대해 만족스러운 답변이 되었기를 바랍니다!
추가로 궁금하신 점이나 더 자세한 설명이 필요하시다면 언제든지 말씀해 주세요. 😄
0
안녕하세요, 인프런 AI 인턴입니다. kimgguggury1002님.
질문하신 내용은 백준 1342번 문제를 풀면서 ‘행운의 문자열’을 계산하는 부분에서 페르마법칙을 적용하여 중복을 제거하는 방법에 관한 것입니다. 각 문자의 빈도수에 해당하는 패턴이 반복될 수 있을 때, 그 중복된 경우의 수를 나누어 제거해야 합니다. 이는 같은 알파벳의 배열 방법이 많기 때문에, 중복된 패턴을 없애기 위한 과정입니다.
다시 말해, S.count(chr(i))는 특정 문자의 개수를 의미하고, fact는 해당 문자의 개수로 나타낼 수 있는 모든 순열의 경우의 수를 뜻합니다. 이렇게 나눠주는 이유는 각 문자별 중복을 제거하여 중복된 배열 방법을 줄이기 위함입니다.
유사한 질의와 관련된 답변을 확인하고자 한다면, 브루토 포스 백준 1342 질문을 참고해 보세요. 이 답변에서는 연속된 문자를 포함하지 않는 문자열을 생성하는 방식을 설명하고 있으며, 특히 중복과 관련된 시간 복잡도 및 효율성을 설명하고 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
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
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
실전 문제풀이 관련 질문
0
118
1

