Lecture

선택 μ •λ ¬ μžμ„Ένžˆ μ•Œμ•„λ³΄κΈ°

1. 반볡문 μ„€μ •

두 개의 μ€‘μ²©λœ λ°˜λ³΅λ¬Έμ„ μ‚¬μš©ν•©λ‹ˆλ‹€. μ™ΈλΆ€ λ°˜λ³΅λ¬Έμ€ 배열을 ν†΅κ³Όν•˜λŠ” 횟수λ₯Ό κ²°μ •ν•˜κ³ , λ‚΄λΆ€ λ°˜λ³΅λ¬Έμ€ μ΅œμ†Œκ°’μ„ μ°ΎκΈ° μœ„ν•΄ λ°°μ—΄μ˜ μš”μ†Œλ₯Ό λΉ„κ΅ν•©λ‹ˆλ‹€.

반볡문 μ„€μ •
for i in range(n): for j in range(i + 1, n):

2. μ΅œμ†Œκ°’ μ°ΎκΈ° 및 κ΅ν™˜

λ‚΄λΆ€ λ°˜λ³΅λ¬Έμ—μ„œ, μ΅œμ†Œκ°’μ„ μ°Ύμ•„ ν˜„μž¬ μœ„μΉ˜μ˜ κ°’κ³Ό κ΅ν™˜ν•©λ‹ˆλ‹€.

μ΅œμ†Œκ°’ μ°ΎκΈ° 및 κ΅ν™˜
if arr[j] < arr[min_index]: min_index = j # μ΅œμ†Œκ°’μ˜ 인덱슀 μ €μž₯ arr[i], arr[min_index] = arr[min_index], arr[i] # μ΅œμ†Œκ°’κ³Ό ν˜„μž¬ μœ„μΉ˜μ˜ κ°’ κ΅ν™˜

선택 μ •λ ¬ μ‹œκ°„ λ³΅μž‘λ„

  1. μ΅œμ•…, μ΅œμ„ , 평균 μ‹œκ°„ λ³΅μž‘λ„ (Worst, Best, and Average-Case Time Complexity): λͺ¨λ‘ O(n^2)

    • 선택 정렬은 λ°°μ—΄μ˜ 각 μœ„μΉ˜μ— λŒ€ν•΄ λ‚˜λ¨Έμ§€ 전체 배열을 νƒμƒ‰ν•˜μ—¬ κ°€μž₯ μž‘μ€(λ˜λŠ” κ°€μž₯ 큰) μš”μ†Œλ₯Ό μ°ΎμŠ΅λ‹ˆλ‹€. 이 과정은 λ°°μ—΄μ˜ 크기가 n일 λ•Œ, 첫 번째 μš”μ†Œμ— λŒ€ν•΄ n-1번, 두 번째 μš”μ†Œμ— λŒ€ν•΄ n-2번 λ“± 총 ((n-1) + (n-2) + ... + 1)번, 즉 n(n-1)/2 번의 비ꡐλ₯Ό ν•„μš”λ‘œ ν•©λ‹ˆλ‹€.

    n(n-1)/2λ₯Ό λΉ…μ˜€ ν‘œκΈ°λ²•μœΌλ‘œ ν‘œκΈ°ν•˜λ©΄, μ‹œκ°„λ³΅μž‘λ„λŠ” O(n^2)κ°€ λ©λ‹ˆλ‹€.

    • 선택 μ •λ ¬μ˜ μ‹œκ°„ λ³΅μž‘λ„λŠ” μž…λ ₯ λ°μ΄ν„°μ˜ μ •λ ¬ μƒνƒœμ— 관계없이 항상 μΌμ •ν•©λ‹ˆλ‹€. 즉, 이미 μ •λ ¬λœ 배열이든, μ—­μˆœμœΌλ‘œ μ •λ ¬λœ 배열이든, λ¬΄μž‘μœ„λ‘œ 배치된 배열이든 μ‹œκ°„ λ³΅μž‘λ„λŠ” λ³€ν•˜μ§€ μ•ŠμŠ΅λ‹ˆλ‹€.

Lecture

AI Tutor

Publish

Design

Upload

Notes

Favorites

Help

Code Editor

Run
Generate

Execution Result