• 카테고리

    질문 & 답변
  • 세부 분야

    알고리즘 · 자료구조

  • 해결 여부

    미해결

중복 제거

24.01.21 23:05 작성 24.01.21 23:06 수정 조회수 116

0

스크린샷 2024-01-21 230431.png

위의 코드도 O(n)의 시간복잡도를 가질까요?

답변 1

답변을 작성해보세요.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.01.23

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

해당 코드의 시간 복잡도는 O(n)이 아닙니다. 리스트에서 pop() 연산은 O(1)의 시간 복잡도를 가지지만, if x not in answer 조건문은 리스트 answer를 처음부터 끝까지 확인하는 과정이 필요하며, 이는 최악의 경우 O(n)의 시간이 걸립니다. 따라서 중첩된 루프가 되며, 전체 시간 복잡도는 O(n^2)이 될 수 있습니다.

코드에서 반복문은 nums 리스트의 각 요소를 한 번씩 확인하되, 조건문은 answer 리스트에 해당 요소가 없는지 매번 확인합니다. answer 리스트의 길이가 길어질수록, in 연산에 더 많은 시간이 소요되므로, 전체적으로 각 요소를 확인하는 데에는 리스트의 길이만큼 시간이 걸립니다.

코드를 개선하여 O(n)의 시간복잡도를 가지게 하려면, 추가적인 자료 구조의 도움을 받아야 합니다. 예를 들어, 집합(Set)을 사용하여 이미 존재하는지 여부를 O(1)의 시간 복잡도로 확인할 수 있습니다.