-
카테고리
-
세부 분야
알고리즘 · 자료구조
-
해결 여부
미해결
투포인터 시간복잡도
23.08.25 19:02 작성 조회수 170
0
http://boj.kr/3e78cb0c919942b99e839ea6eb90dfa6
해당 코드에서 투포인터를 사용시 시간복잡도가
n log n(퀵 sort) + n (while 문) 으로 제가 생각을 해봤는데 맞을까요??
답변을 작성해보세요.
1
큰돌
지식공유자2023.08.27
안녕하세요 자르트님 ㅎㅎ
n log n(퀵 sort) + n (while 문) 으로 제가 생각을 해봤는데 맞을까요??
>> 네 맞습니다. 이제 고수시네요.. ㅎㅎ
또 질문 있으시면 언제든지 질문 부탁드립니다.
좋은 수강평과 별점 5점은 제게 큰 힘이 됩니다. :)
감사합니다.
강사 큰돌 올림.
0
0
인프런 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)이 됩니다. 제가 맞게 이해하고 답변드린 것이 맞는지요. 다른 궁금하신 점이 있으면 언제든지 물어보세요!
답변 3