• 카테고리

    질문 & 답변
  • 세부 분야

    알고리즘 · 자료구조

  • 해결 여부

    미해결

투포인터 시간복잡도

23.08.25 19:02 작성 조회수 170

0

http://boj.kr/3e78cb0c919942b99e839ea6eb90dfa6

 

해당 코드에서 투포인터를 사용시 시간복잡도가

n log n(퀵 sort) + n (while 문) 으로 제가 생각을 해봤는데 맞을까요??

답변 3

·

답변을 작성해보세요.

1

안녕하세요 자르트님 ㅎㅎ

n log n(퀵 sort) + n (while 문) 으로 제가 생각을 해봤는데 맞을까요??

>> 네 맞습니다. 이제 고수시네요.. ㅎㅎ

 

또 질문 있으시면 언제든지 질문 부탁드립니다.

좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)

감사합니다.

강사 큰돌 올림.


0

자르트님의 프로필

자르트

질문자

2023.08.28

답변 항상 감사드립니다 큰돌님 :)

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2023.08.27

안녕하세요, 인프런 AI 인턴이에요.

주어진 코드에서 투포인터를 사용하는 경우, 시간 복잡도는 일반적으로 투포인터가 수행되는 부분에 따라 다를 수 있습니다. 하지만 말씀하신 내용으로 보아 기존의 퀵 정렬 알고리즘과 while 문을 통한 투포인터가 사용된 것으로 보입니다.

일반적으로 퀵 정렬의 시간 복잡도는 평균적으로 O(n log n)이며, 최악의 경우 O(n^2)가 될 수 있습니다. 따라서 퀵 정렬부분의 시간 복잡도는 O(n log n)으로 보시면 됩니다. 이후 while 문을 통해 투포인터가 수행되는데, 이 부분은 배열을 한 번씩 순회하는 과정으로 볼 수 있으므로 O(n)의 시간 복잡도를 가질 수 있습니다.

따라서 총 시간 복잡도는 O(n log n) + O(n)이 됩니다. 제가 맞게 이해하고 답변드린 것이 맞는지요. 다른 궁금하신 점이 있으면 언제든지 물어보세요!