작성
·
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)이 됩니다. 제가 맞게 이해하고 답변드린 것이 맞는지요. 다른 궁금하신 점이 있으면 언제든지 물어보세요!