학습 자료

알고리즘의 복잡도(Complexity)란?

알고리즘의 복잡도는 알고리즘이 얼마나 효율적인지를 평가하는 방법으로, 보통 빅 오 표기법(Big O notation)으로 표현합니다.

빅 오 표기법은 입력 크기에 따라 알고리즘의 실행 시간이나 메모리 사용량이 어떻게 증가하는지를 나타내며, 아래와 같은 형태로 표현됩니다.

표기법명칭설명
O(1)상수 시간 복잡도입력 크기에 관계없이 일정한 시간이 소요되는 경우
O(log n)로그 시간 복잡도입력 크기의 로그에 비례하여 시간이 증가하는 경우
O(n)선형 시간 복잡도입력 크기에 비례하여 시간이 증가하는 경우
O(n log n)선형 로그 시간 복잡도입력 크기의 선형 로그에 비례하여 시간이 증가하는 경우
O(n²)제곱 시간 복잡도입력 크기의 제곱에 비례하여 시간이 증가하는 경우
O(2ⁿ)지수 시간 복잡도입력 크기의 지수에 비례하여 시간이 증가하는 경우

여기서 On의 의미는 다음과 같습니다.

  • 'O' (Big O): 알고리즘의 차수(Order)를 나타내며, 시간 복잡도와 공간 복잡도를 측정합니다. OOrder of의 약자로, 알고리즘이 입력 크기에 따라 요구하는 계산량이나 메모리 사용량의 상한선을 의미합니다.

  • 'n': 일반적으로 알고리즘의 입력 크기를 나타내는 변수입니다.


예를 들어 각 복잡도의 의미는 다음과 같습니다.

  • O(1)은 알고리즘의 실행 시간이 입력 크기와 관계없이 일정한 시간이 소요

  • O(n)은 알고리즘의 실행 시간이 입력 크기에 선형적으로 비례하여 증가

  • O(n²)은 실행 시간이 입력 크기의 제곱에 비례하여 기하급수적으로 증가


알고리즘의 복잡도 평가

알고리즘의 복잡도는 시간 복잡도공간 복잡도 두 가지 측면에서 평가됩니다.


시간 복잡도 (Time Complexity)

시간 복잡도는 알고리즘이 문제를 해결하는 데 소요되는 시간을 나타냅니다.

주로 입력 크기에 따라 필요한 연산 단계의 수로 측정됩니다.

예를 들어, 단순 반복문은 입력 크기에 비례하여 수행되므로 선형 시간 복잡도, 즉 O(n)의 시간 복잡도를 갖습니다.

반면 for문 속에 또 다른 for문이 중첩되어 있는 경우, 입력 크기의 제곱만큼 연산이 필요하므로 제곱 시간 복잡도, 즉 O(n²)의 시간 복잡도를 갖습니다.


공간 복잡도 (Space Complexity)

공간 복잡도는 알고리즘 실행 시 필요한 메모리 공간의 양을 나타냅니다.

메모리 공간의 양은 알고리즘이 사용하는 변수, 데이터 구조, 재귀 호출 스택 등의 크기를 포함합니다.

예를 들어, 고정된 수의 변수만 사용하는 경우는 상수 공간 복잡도, 즉 O(1)의 공간 복잡도를 갖습니다.

반면 입력 크기에 비례하는 메모리가 필요한 경우는 선형 공간 복잡도, 즉 O(n)의 공간 복잡도를 갖습니다.

Mission
0 / 1

다음 중 선형 시간 복잡도를 빅 오 표기법으로 나타낸 것은 무엇일까요?

O(1)

O(log n)

O(n)

O(n²)

학습 자료

AI 튜터

배포

디자인

업로드

수업 노트

즐겨찾기

도움말

코드 에디터

코드 실행
코드 생성

실행 결과