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

자르트님의 프로필 이미지
자르트

작성한 질문수

10주완성 C++ 코딩테스트 | 알고리즘 코딩테스트

5-A

투포인터 시간복잡도

작성

·

234

0

http://boj.kr/3e78cb0c919942b99e839ea6eb90dfa6

 

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

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

답변 3

1

큰돌님의 프로필 이미지
큰돌
지식공유자

안녕하세요 자르트님 ㅎㅎ

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

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

 

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

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

감사합니다.

강사 큰돌 올림.


0

자르트님의 프로필 이미지
자르트
질문자

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

0

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

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

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

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

자르트님의 프로필 이미지
자르트

작성한 질문수

질문하기