ν°μ€ν 리 λ·°
ν μ λ ¬
: κΈ°λ³Έ μμ΄λμ΄λ λ²λΈ μ λ ¬κ³Ό λΉμ·νλ€.
1λ±μ λ½μλ΄κ³ , λλ¨Έμ§ μμμμ 1λ±μ κ³μ λ½μλ΄λ©° μ λ ¬νλ€.
λ²λΈ μ λ ¬κ³Ό λ€λ₯Έ μ μ, λ²λΈ μ λ ¬μ λ¨μ μμμμ 1λ±μ λ€μ λΉκ΅λ₯Ό ν΅ν΄ μ°ΎμμΌ νμ§λ§
ν μ λ ¬μ ν(Heap)μ μ΄μ©νλ©΄, 1λ±μ λ½μλΈ λ€, λλ¨Έμ§ μμμμ 1λ±μ λ½μ λ λ€μ λΉκ΅ν νμ μμ΄ 2λ±μ΄ μλμΌλ‘ 1λ±μ΄ λλ€.
κ·ΈλΌ, ν(Heap)μ λν΄ μ κΉ μμ보μ.
νμ μ±μ§
1. 리ν λ Έλλ₯Ό μ μΈν λͺ¨λ λ Έλλ μμμ΄ λ°λμ 2λͺ
2. Max heap: λΆλͺ¨λ μμλ³΄λ€ λ°λμ ν¬λ€. Min heap: λΆλͺ¨λ μμλ³΄λ€ λ°λμ μλ€.
νμ μ½μ κ³Ό μμ (μΆμ²: https://guides.codepath.com/compsci/Heaps)
μ, μ΄μ ν μ λ ¬μ λν΄ λ³Έκ²©μ μΌλ‘ λ€μ΄κ°λ³΄μ.
μ°μ λ€μκ³Ό κ°μ ν° μ€κΈ°λ₯Ό κ°μ§λ€.
" Heapify(νμΌλ‘ λ§λ€κΈ°) " -> " μ λ ¬"
λ°±λ¬Έμ΄ λΆμ¬μΌRun [3, 5, 7, 9, 4, 2]λ₯Ό μ λ ¬ν΄λ³΄μ.
1) Heapify
2) μ λ ¬
μ΄μ λμΌν κ³Όμ μ λ°°μ΄λ‘ ννν κ³Όμ λ κ°μ΄ μ°Έκ³ ν΄μ μ΄ν΄ν΄λ³΄μ.
(μΆμ²: https://www.youtube.com/watch?v=gB7qYgikT1Y)
μκ° λ³΅μ‘λ
: O(nlogn)
'π§π»βπ» μκ³ λ¦¬μ¦ > μ λ ¬' μΉ΄ν κ³ λ¦¬μ λ€λ₯Έ κΈ
[μ λ ¬] 8. ν μ΄λ μ΄ν΄νλ κ³μ μ λ ¬(Counting Sort) (0) | 2022.11.30 |
---|---|
[μ λ ¬] 7. ν μ΄λ μ΄ν΄νλ κΈ°μ μ λ ¬(radix sort) (0) | 2022.11.30 |
[μ λ ¬] 5. ν΅ μ λ ¬ (0) | 2022.11.30 |
[μ λ ¬] 2. μ ν μ λ ¬ (0) | 2022.11.30 |
[μ λ ¬] 4.λ³ν©μ λ ¬(Merge sort) (0) | 2022.11.29 |
- Total
- Today
- Yesterday
- git
- Context API
- useState
- μλ°μ€ν¬λ¦½νΈ
- νμ΄μ¬
- μκ³ λ¦¬μ¦
- CSS
- μ λ ¬
- Component
- DB
- react
- 리μ‘νΈ
- github
- μλ¬
- state
- λΈλΌμ°μ
- Browser
- leetcode
- mdn
- DOM
- Python
- zustand
- BOJ
- error
- ν¨μ
- κ·Έλν
- λ°μ΄ν°λ² μ΄μ€
- React Query
- μλ£κ΅¬μ‘°
- JavaScript
μΌ | μ | ν | μ | λͺ© | κΈ | ν |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |