인프런 커뮤니티 질문&답변

오이오님의 프로필 이미지
오이오

작성한 질문수

파이썬 알고리즘 문제풀이 입문(코딩테스트 대비)

10. 역수열(그리디)

질문

작성

·

23

0

seq[5]이 0인 경우에만 1이 들어가고 만약 0이 아니면 seq[6]의 자리에 1이 들어가야 하는데, 이러한 로직이 어디서 구현되고 있는건지 잘 감이 안옵니다.

답변 1

0

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

해당 문제의 핵심은 “역수열”을 구성하는 방법을 이해하는 것입니다. 다른 수열 문제와 달리 역수열은 특정 조건에 맞춰 수를 배치해야 하는데요, 이 과정에서 필요한 논리와 구현 방법이 혼동될 수 있습니다.

이전의 유사한 질문과 답변을 참고하실 수 있는 링크를 안내해드립니다:

그리고, 역수열을 구성하는 데 필요한 중요한 논리 설명을 포함하도록 하겠습니다:

  1. 리스트 초기화: seq 리스트를 초기화하여 모든 원소를 0으로 만들고 시작합니다.
  2. 위치 찾기: 주어진 조건에 맞춰 숫자를 seq 리스트의 적절한 위치에 배치합니다. 이 과정에서 특정 숫자가 0이 되는 순간에 주의해야 합니다.
  3. 숫자 배치: 만약 해당 위치가 아닌 다음 위치에 숫자를 배치해야 하는 경우, 인덱스를 계속 증가시키며 조건을 충족할 때까지 반복합니다.

예제 코드 참고:

n = 5
seq = [0] * n
a = [2, 1, 1, 0, 0]

for i in range(n):
    count = 0
    for j in range(n):
        if count == a[i] and seq[j] == 0:
            seq[j] = i + 1
            break
        elif seq[j] == 0:
            count += 1

print(seq)

위 코드에서 counta[i]와 같은지 확인하고, seq[j]가 0인 경우에만 값을 배치한다는 논리를 구현하고 있습니다. 이러한 방식으로 역수열을 구성하게 됩니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

오이오님의 프로필 이미지
오이오

작성한 질문수

질문하기