> 백엔드 개발 > 파이썬 튜토리얼 > 알고리즘의 시간 복잡도를 찾는 쉬운 방법

알고리즘의 시간 복잡도를 찾는 쉬운 방법

DDD
풀어 주다: 2024-11-22 02:15:11
원래의
641명이 탐색했습니다.

Easy way to find the Time Complexity of an Algorithm

시간 복잡도는 이제 막 문제 해결을 시작한 초보자에게 가장 어려운 주제 중 하나로 간주됩니다. 여기서는 시간 복잡도 분석 치트 시트를 제공합니다. 이것이 도움이 되기를 바랍니다. 궁금한 점이 있으면 알려주세요.

시간 복잡도 분석 치트시트

빠른 참조 테이블

O(1)       - Constant time
O(log n)   - Logarithmic (halving/doubling)
O(n)       - Linear (single loop)
O(n log n) - Linearithmic (efficient sorting)
O(n²)      - Quadratic (nested loops)
O(2ⁿ)      - Exponential (recursive doubling)
O(n!)      - Factorial (permutations)
로그인 후 복사

패턴 식별

1. O(1) - 상수

# Look for:
- Direct array access
- Basic math operations
- Fixed loops
- Hash table lookups

# Examples:
arr[0]
x + y
for i in range(5)
hashmap[key]
로그인 후 복사

2. O(log n) - 로그

# Look for:
- Halving/Doubling
- Binary search patterns
- Tree traversal by level

# Examples:
while n > 0:
    n = n // 2

left, right = 0, len(arr)-1
while left <= right:
    mid = (left + right) // 2
로그인 후 복사

3. O(n) - 선형

# Look for:
- Single loops
- Array traversal
- Linear search
- Hash table building

# Examples:
for num in nums:
    # O(1) operation
    total += num

for i in range(n):
    # O(1) operation
    arr[i] = i
로그인 후 복사

4. O(n log n) - 선형

# Look for:
- Efficient sorting
- Divide and conquer
- Tree operations with traversal

# Examples:
nums.sort()
sorted(nums)
merge_sort(nums)
로그인 후 복사

5. O(n²) - 2차

# Look for:
- Nested loops
- Simple sorting
- Matrix traversal
- Comparing all pairs

# Examples:
for i in range(n):
    for j in range(n):
        # O(1) operation

# Pattern finding
for i in range(n):
    for j in range(i+1, n):
        # Compare pairs
로그인 후 복사

6. O(2ⁿ) - 지수

# Look for:
- Double recursion
- Power set
- Fibonacci recursive
- All subsets

# Examples:
def fib(n):
    if n <= 1: return n
    return fib(n-1) + fib(n-2)

def subsets(nums):
    if not nums: return [[]]
    result = subsets(nums[1:])
    return result + [nums[0:1] + r for r in result]
로그인 후 복사

공통 작업 시간 복잡성

배열/목록 작업

# O(1)
arr[i]              # Access
arr.append(x)       # Add end
arr.pop()           # Remove end

# O(n)
arr.insert(i, x)    # Insert middle
arr.remove(x)       # Remove by value
arr.index(x)        # Find index
min(arr), max(arr)  # Find min/max
로그인 후 복사

사전/집합 작업

# O(1) average
d[key]              # Access
d[key] = value      # Insert
key in d            # Check existence
d.get(key)          # Get value

# O(n)
len(d)              # Size
d.keys()            # Get keys
d.values()          # Get values
로그인 후 복사

문자열 연산

# O(n)
s + t               # Concatenation
s.find(t)           # Substring search
s.replace(old, new) # Replace
''.join(list)       # Join

# O(n²) potential
s += char           # Repeated concatenation
로그인 후 복사

루프 분석

단일 루프

# O(n)
for i in range(n):
    # O(1) operations

# O(n/2) = O(n)
for i in range(0, n, 2):
    # Skip elements still O(n)
로그인 후 복사

중첩 루프

# O(n²)
for i in range(n):
    for j in range(n):
        # O(1) operations

# O(n * m)
for i in range(n):
    for j in range(m):
        # Different sizes

# O(n²/2) = O(n²)
for i in range(n):
    for j in range(i, n):
        # Triangular still O(n²)
로그인 후 복사

다중 루프

# O(n + m)
for i in range(n):
    # O(1)
for j in range(m):
    # O(1)

# O(n + n²) = O(n²)
for i in range(n):
    # O(1)
for i in range(n):
    for j in range(n):
        # O(1)
로그인 후 복사

재귀 분석

선형 재귀

# O(n)
def factorial(n):
    if n <= 1: return 1
    return n * factorial(n-1)
로그인 후 복사

이진 재귀

# O(2ⁿ)
def fibonacci(n):
    if n <= 1: return n
    return fibonacci(n-1) + fibonacci(n-2)
로그인 후 복사

분할 및 정복

# O(n log n)
def mergeSort(arr):
    if len(arr) <= 1: return arr
    mid = len(arr) // 2
    left = mergeSort(arr[:mid])
    right = mergeSort(arr[mid:])
    return merge(left, right)
로그인 후 복사

최적화 위험 신호

숨겨진 루프

# String operations
for c in string:
    newStr += c  # O(n²)

# List comprehension
[x for x in range(n) for y in range(n)]  # O(n²)
로그인 후 복사

내장 기능

len()           # O(1)
min(), max()    # O(n)
sorted()        # O(n log n)
list.index()    # O(n)
로그인 후 복사

분석을 위한 팁

  1. 중첩 루프 계산
  2. 재귀 분기 확인
  3. 숨겨진 작업 고려
  4. 분할과 정복을 찾아보세요
  5. 내장 함수 복잡도 확인
  6. 평균과 최악의 경우 고려
  7. 루프 변수 감시
  8. 입력 제약 고려

읽어 주셔서 감사합니다. 이 글이 도움이 되었다면 게시물에 좋아요를 눌러주세요. 건배!

위 내용은 알고리즘의 시간 복잡도를 찾는 쉬운 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:dev.to
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿