๐Ÿฅ•
TIL
  • [TIL] Studying tech / computer science knowledge
  • KeyMap
  • ์•Œ๊ณ ๋ฆฌ์ฆ˜
    • ๋ณต์žก๋„ ๊ณ„์‚ฐ ( Computational Complexity )
    • DisjointSet-unionFind
    • Bellman-ford Algorithm
    • Dijkstra's Algorithm
    • DP ( Dynamic Programming , ๋™์  ๊ณ„ํš๋ฒ• )
    • ํ”Œ๋กœ์ด๋“œ-์›Œ์…œ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (Floyd-Warshall algorithm)
    • Kruskal's Algorithm
    • ์ตœ์žฅ ์ฆ๊ฐ€ ์ˆ˜์—ด (Longes Increasing Subsequence)
    • Prim's Algorithm
    • ์ •๋ ฌ
    • ์‹œ๊ฐ„๋ณต์žก๋„ ์™€ ๊ณต๊ฐ„๋ณต์žก๋„ ( Time Complexity & Space Complexity )
    • Topological Sort (์œ„์ƒ ์ •๋ ฌ)
  • ์ฑ… ์ฝ๊ณ ๋‚œ ํ›„ ์š”์•ฝ
    • ํ”„๋กœ๊ทธ๋ž˜๋ฐ ๋Œ€ํšŒ์—์„œ ๋ฐฐ์šฐ๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜ ๋ฌธ์ œํ•ด๊ฒฐ ์ „๋žต
    • cleancode
    • ๋„๋ฉ”์ธ ์ฃผ๋„ ์„ค๊ณ„๋กœ ์‹œ์ž‘ํ•˜๋Š” ๋งˆ์ดํฌ๋กœ์„œ๋น„์Šค ๊ฐœ๋ฐœ
    • ์˜ค๋ธŒ์ ํŠธ
  • CDC
    • debzium
    • kafka
  • ๊ฐœ๋ฐœ ์ƒ์‹
    • asciidoctor
    • ์ปดํŒŒ์ผ๋Ÿฌ
    • ELK ์Šคํƒ
    • ์—”๋””์•ˆ
    • git
    • Gitmoji
    • ํ…Œ์ŠคํŠธ ์ข…๋ฅ˜
    • ๋ผ์ด๋ธŒ๋Ÿฌ๋ฆฌ์™€ ํ”„๋ ˆ์ž„์›Œํฌ
    • ์ •๊ทœ ํ‘œํ˜„์‹
    • REST API
    • ๋™๊ธฐ์™€ ๋น„๋™๊ธฐ / Blocking๊ณผ NonBlocking
    • Transaction Script์™€ Domain Model
    • ๋””์ž์ธ ํŒจํ„ด
      • ํ–‰๋™ ํŒจํ„ด
      • ๊ฐ์ฒด ์ƒ์„ฑ ํŒจํ„ด
        • ์ถ”์ƒ ํŒฉํ† ๋ฆฌ ํŒจํ„ด
        • ๋นŒ๋” ํŒจํ„ด
        • ํŒฉํ† ๋ฆฌ ๋ฉ”์„œ๋“œ ํŒจํ„ด
        • [์ƒ์„ฑ ํŒจํ„ด] ํ”„๋กœํ†  ํƒ€์ž… (Prototype Parttern)
        • ์‹ฑ๊ธ€ํ†ค
      • ๊ตฌ์กฐ ํŒจํ„ด
        • ์–ด๋Œ‘ํ„ฐ ํŒจํ„ด
        • ๋ธŒ๋ฆฟ์ง€ ํŒจํ„ด
        • ์ปดํฌ์ง“(Composite) ํŒจํ„ด
        • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ
        • ํ”„๋ก์‹œ
    • refactoring
      • ์ค‘๋ณต ์ฝ”๋“œ
      • ์ „์—ญ ๋ฐ์ดํ„ฐ
      • ๊ธด ํ•จ์ˆ˜
      • ๊ธด ๋งค๊ฐœ๋ณ€์ˆ˜ ๋ชฉ๋ก
      • ๊ฐ€๋ณ€ ๋ฐ์ดํ„ฐ
      • ์ดํ•ดํ•˜๊ธฐ ํž˜๋“  ์ด๋ฆ„
  • ์ž๋ฃŒ๊ตฌ์กฐ
    • AVL Tree
    • Splay Tree
    • aaTree
    • array-list
    • ์ž๋ฃŒ๊ตฌ์กฐ ์‹œ๊ฐ„/๊ณต๊ฐ„ ๋ณต์žก๋„
    • ๊ทธ๋ž˜ํ”„
    • ํž™
    • Red Black Tree
    • stack-queue
    • ํŠธ๋ฆฌ ( Tree )
  • DevOps
    • MSA
    • Kubernetes
      • AccessingAPI
      • controller
      • dashboard
      • kubernetes
      • object
      • pod
      • service
      • volume
  • Java
    • ์–ด๋…ธํ…Œ์ด์…˜
    • ์ œ์–ด๋ฌธ
    • ๋ฐ์ดํ„ฐ ํƒ€์ž…
    • Enum
    • jvm
    • ์—ฐ์‚ฐ์ž
    • thread
    • Java8
      • CompletableFuture
      • Date/Time
      • ์–ด๋…ธํ…Œ์ด์…˜๊ณผ ๋ฉ”ํƒ€์ŠคํŽ˜์ด์Šค
      • ์ธํ„ฐํŽ˜์ด์Šค
      • ๋žŒ๋‹ค์‹
      • Optional
      • ์ŠคํŠธ๋ฆผ
  • JavaScript
    • moduleProject
    • webpack-babel
    • ์ฝ”์–ด ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      • array
      • ํ•จ์ˆ˜ ๋ฐ”์ธ๋”ฉ
      • ๋ฐ์ฝ”๋ ˆ์ดํ„ฐ์™€ ํฌ์›Œ๋”ฉ
      • Class
      • ๋น„๊ต ์—ฐ์‚ฐ์ž
      • Date ๋‚ด์žฅ ๊ฐ์ฒด
      • destructuring-assignment
      • function
      • ํ•จ์ˆ˜์˜ prototype ํ”„๋กœํผํ‹ฐ
      • ๊ฐ€๋น„์ง€ ์ปฌ๋ ‰์…˜ ( Garbage Collection )
      • JSON (JavaScript Object Notation)
      • map-set
      • ๋‚ด์žฅ ํ”„๋กœํ† ํƒ€์ž…
      • new์—ฐ์‚ฐ์ž์™€ ์ƒ์„ฑ์ž ํ•จ์ˆ˜
      • ๊ฐ์ฒด
      • Object.keys, values, entries
      • ์˜ต์…”๋„ ์ฒด์ด๋‹ '?.'
      • ํ”„๋กœํผํ‹ฐ ํ”Œ๋ž˜๊ทธ
      • ํ”„๋กœํผํ‹ฐ ์ข…๋ฅ˜
      • ํ”„๋กœํ†  ํƒ€์ž…
      • ํ˜ธ์ถœ ์Šค์ผ€์ค„๋ง ( scheduling a call )
      • scope
      • this
      • type-conversions
      • type
      • ํ•จ์ˆ˜์˜ ์ž๋ฃŒํ˜•
      • var_let_const
  • Linux
    • ๊ธฐ๋ณธ ๋ช…๋ น์–ด
    • ํŒŒ์ผ ์ข…๋ฅ˜
    • ๋ฆฌ๋ˆ…์Šค
  • ๋„คํŠธ์›Œํฌ
    • ์‘์šฉ ๊ณ„์ธต ( Application Layer )
    • ์˜ค๋ฅ˜ ๊ฒ€์ถœ๊ณผ ์˜ค๋ฅ˜ ์ •์ •
    • Http
    • Http Header
    • ์ปดํ“จํ„ฐ ๋„คํŠธ์›Œํฌ๋ž€
    • ๋„คํŠธ์›Œํฌ ๊ณ„์ธต
    • ๋„คํŠธ์›Œํฌ ์ œ์–ด ์˜์—ญ
    • ์ „์†ก ๊ณ„์ธต ( Transport Layer )
  • PHP
    • Facade
    • composer
    • scopeResolutionOperator
    • Laravel
      • SocialProvider
      • architecture
      • blade
      • controller
      • db
      • dbArchitecture
      • debug
      • eloquent
      • email
      • event
      • exceptionHandling
      • middleware
      • model
      • modelFactory
      • pagingLoading
      • queryBuilder
      • route
      • scout
      • seeding
      • tntsearch
      • validate
      • view
  • React
    • Next.js
    • React ๋ž€?
  • Spring
    • Controller
    • ์š”์ฒญ์ด ๋“ค์–ด์™”์„๋•Œ ์Šคํ”„๋ง์ด ์ฒ˜๋ฆฌํ•˜๋Š” ๋ฐฉ๋ฒ• ( ๋‚ด๋ถ€๊ตฌ์กฐ )
    • ConfigurationProperties
    • Entity / DTO / VO
    • Maven
    • Repository์™€ DAO
    • ์Šคํ”„๋ง ๋นˆ
    • Spring Framework
    • MVC ํŒจํ„ด
    • ๋„๋ฉ”์ธ ์ž…๋ ฅ๊ฐ’ ๊ฒ€์ฆ
    • Spring Cloud
      • Spring Cloud
      • Eureka
    • Spring Data
      • JPA
      • JPA ์–ด๋…ธํ…Œ์ด์…˜
      • ์—”ํ‹ฐํ‹ฐ ๋น„๊ต
      • ๋ณตํ•ฉ ํ‚ค์™€ ์‹๋ณ„ ๊ด€๊ณ„ ๋งคํ•‘
      • JPA ์˜ˆ์™ธ์ฒ˜๋ฆฌ
      • ๊ฐ์ฒด์ง€ํ–ฅ ์ฟผ๋ฆฌ
      • EntityManagerFactory์™€ EntityManager
      • JPA ์ตœ์ ํ™”
      • ํ”„๋ก์‹œ์™€ ์—ฐ๊ด€๊ด€๊ณ„ ๋งตํ•‘
      • ์—ฐ๊ด€๊ด€๊ณ„
      • ์ƒ์†๊ด€๊ณ„ ๋งตํ•‘
      • ํŠธ๋žœ์žญ์…˜ ๋ฒ”์œ„์™€ ์˜์†์„ฑ ์ปจํ…์ŠคํŠธ
      • ๋ฐ์ดํ„ฐ ํƒ€์ž…
      • MySQL ์—ฐ๊ฒฐ
      • Pageable
    • Spring Project๋“ค๊ณผ library
      • Custom Serialize
      • Elasticsearch Index API
      • Spring HATEOAS
      • lombok (๋กฌ๋ณต)
      • Model Mapper
      • Object Mapper
      • Representation Model
      • Spring REST Docs
      • Spring Boot
    • Spring Security
      • Spring Security
      • Authentication
      • Authentication Filter
      • Authorization Filter
      • Filter Chain
      • SecurityContext
      • Spring OAuth2.0
    • Spring Test
      • AssertJ
      • Junit5
      • JunitParams
      • Mock Object
  • DataBase
    • ALIAS
    • CONCAT
    • CTE
    • Group By
    • HAVING
    • IFNULL
    • ์ธ๋ฑ์Šค
    • JOIN
    • ORDER BY
    • ROLLUP
    • SELECT
    • SELECT DISTINCT
    • SQL
    • WHERE
  • Web ์ƒ์‹
    • OAuth
    • WAS
    • HTTPํ†ต์‹  ๊ธฐ๋ฐ˜ ์ธ์ฆ
    • ๋ธŒ๋ผ์šฐ์ €
    • CSR ๊ณผ SSR
    • HTTPS
    • Web
Powered by GitBook
On this page
  • RB Tree 4๊ฐ€์ง€ ์กฐ๊ฑด
  • ํŠน์ง•
  • ์‚ฌ์šฉ์˜ˆ
  • ์žฅ์  (ํ•ด์‰ฌ์™€ ๋น„๊ตํ•ด์„œ)
  • ๊ตฌํ˜„
  • ์‹œ๊ฐ„ ๋ณต์žก๋„
  1. ์ž๋ฃŒ๊ตฌ์กฐ

Red Black Tree

BST (์ด์ง„ ํƒ์ƒ‰ ํŠธ๋ฆฌ)๋ฅผ ๊ธฐ๋ฐ˜์œผ๋กœ ๋‘” Tree.

๊ฐ ๋…ธ๋“œ๋Š” ๊ฐ’(key)๋ง๊ณ ๋„ ์ƒ‰์„ ๊ฐ–๊ณ  ์ƒ‰์€ ๋ ˆ๋“œ or ๋ธ”๋ž™ 2์ข…๋ฅ˜๋‹ค.

์‚ฝ์ž…, ์‚ญ์ œ, ํƒ์ƒ‰์˜ ์‹œ๊ฐ„๋ณต์žก๋„๋Š” O(log n)

RB Tree 4๊ฐ€์ง€ ์กฐ๊ฑด

1. Root Property : ๋ฃจํŠธ(root)๋…ธ๋“œ๋Š” ๋ธ”๋ž™(black)์ด๋‹ค.
2. External Property : ๋ชจ๋“  ์™ธ๋ถ€ ๋…ธ๋“œ (external node)๋Š” ๋ธ”๋ž™์ด๋‹ค.
3. Depth Property : ๋ชจ๋“  ๋‹จ๋ง ๋…ธ๋“œ(leaf node)์˜ ๊ฒฝ์šฐ ๋ฃจํŠธ๋ถ€ํ„ฐ ์™ธ๋ถ€ ๋…ธ๋“œ ๊นŒ์ง€ ๋ฐฉ๋ฌธํ•˜๋Š” ๋ธ”๋ž™ ๋…ธ๋“œ์˜ ์ˆ˜๊ฐ€ ๊ฐ™๋‹ค.
4. Internal Property : ๋นจ๊ฐ• ๋…ธ๋“œ์˜ ์ž์‹์€ ๋ธ”๋ž™์ด๋‹ค.
    == No Double Red :๋ ˆ๋“œ ๋…ธ๋“œ๋Š” ๋‘๊ฐœ๊ฐ€ ์—ฐ์†ํ•ด์„œ ์˜ฌ ์ˆ˜ ์—†๋‹ค.

ํŠน์ง•

  • BST์˜ ๋ชจ๋“  ํŠน์ง•์„ ๊ฐ–๋Š”๋‹ค.

  • ๋…ธ๋“œ์˜ ์ž์‹์ด ์—†๋Š” ๊ฒฝ์šฐ ์ž์‹์„ ๊ฐ€๋ฆฌํ‚ค๋Š” ํฌ์ธํ„ฐ๋Š” NULL๊ฐ’์„ ์ €์žฅ ( NULL์„ leaf node๋กœ ๊ฐ„์ฃผ)

  • ๋ฃจํŠธ ๋…ธ๋“œ ๋ถ€ํ„ฐ ๋‹จ๋ง ๋…ธ๋“œ(leaf node)๊นŒ์ง€ ๋ชจ๋“  ๊ฒฝ๋กœ ์ค‘ ์ตœ์†Œ ๊ฒฝ๋กœ์™€ ์ตœ๋Œ€ ๊ฒฝ๋กœ์˜ ํฌ๊ธฐ ๋น„์œจ์€ 2๋ณด๋‹ค ํฌ์ง€ ์•Š๋‹ค. ( balanced ์ƒํƒœ )

์‚ฌ์šฉ์˜ˆ

  • Java Collection์˜ ArrayList

  • HashMap์˜ Separate Chaining

  • C++ map

์žฅ์  (ํ•ด์‰ฌ์™€ ๋น„๊ตํ•ด์„œ)

  • ์ˆœ์„œ๊ฐ€ ์žˆ๋Š” ์ž๋ฃŒ์ผ ๊ฒฝ์šฐ ์ข‹๋‹ค. ( ํ•ด์‰ฌ๋Š” ์ˆœ์„œ๊ฐ€ ์—†์Œ )

  • ์ผ๊ด€์„ฑ์žˆ๋Š” ํผํฌ๋จผ์Šค๋ฅผ ๋ณด์—ฌ์ค€๋‹ค. ( ํ•ด์‰ฌ๋Š” rehashing์‹œ ๋น„์ •์ƒ์  ์‹œ๊ฐ„์ด ๊ฑธ๋ฆด ์ˆ˜ ์žˆ์Œ )

  • ํ•ด์‰ฌ๋Š” ํŽ˜์ด์ง€ํดํŠธ๋ฅผ ์ผ์œผํ‚ฌ ์ˆ˜ ์žˆ๋‹ค.

  • ์—ฐ์†๋œ ์‚ฝ์ž…๊ฐ„์˜ ๊ณต๊ฐ„ ์ง€์—ญ์„ฑ์„ ์œ ์ง€ํ•˜๊ธฐ ์‰ฝ๋‹ค. ( ๋” ์ ์€ I/O ๋ฐœ์ƒ)

  • ํŠธ๋ฆฌ๋Š” ๋ถ€์ •ํ™•ํ•œ ๊ฒ€์ƒ‰์— ์‚ฌ์šฉ๋  ์ˆ˜ ์žˆ๋‹ค.

๊ตฌํ˜„

  • Insert ( ์‚ฝ์ž… )

BST ํŠน์ง•๋Œ€๋กœ ์‚ฝ์ž… ํ›„, ์‚ฝ์ž… ๋…ธ๋“œ์˜ ์ƒ‰๊น”์„ RED๋กœ ์„ค์ •.
์‚ฝ์ž… ํ›„ RBT์˜ ํŠน์ง•์„ ์œ„๋ฐฐํ•  ์‹œ ๋…ธ๋“œ์˜ ์ƒ‰๊น”์„ ์กฐ์ •ํ•˜๊ณ ,
Black-Height๊ฐ€ ์œ„๋ฐฐ๋˜์—ˆ๋‹ค๋ฉด, rotation์„ ํ†ตํ•˜์—ฌ height์„ ์กฐ์ •.

์ด๋•Œ, ์—ฌ๋Ÿฌ case๊ฐ€ ์กด์žฌํ•˜๋Š” ๋ฐ, ์ƒˆ๋กœ ์‚ฝ์ž…ํ•œ ๋…ธ๋“œ๋ฅผ z๋ผ๊ณ  ํ• ๋•Œ,
๋ถ€๋ชจ ๋…ธ๋“œ์ธ p[z]๊ฐ€ ๋ถ€๋ชจ ๋…ธ๋“œ์˜ ๋ถ€๋ชจ ๋…ธ๋“œ์ธ ํ• ์•„๋ฒ„์ง€ ๋…ธ๋“œ p[p[z]]์˜ ์™ผ์ชฝ ์ž์‹์ธ์ง€ ์˜ค๋ฅธ์ชฝ ์ž์‹์ธ์ง€์— ๋”ฐ๋ผ case๊ฐ€ ๋‚˜๋‰˜๊ฒŒ ๋œ๋‹ค.
๋‘๊ฐœ์˜ ๊ฒฝ์šฐ๊ฐ€ ์„œ๋กœ ๋Œ€์นญ์ด๋‹ค.

 red-black tree๊ทœ์น™์ด ์œ„๋ฐฐ๋ ๋•Œ ํฌ๊ฒŒ ๋ณด๋ฉด ์•„๋ž˜์™€ ๊ฐ™์ด 2๊ฐ€์ง€์˜ ๊ฒฝ์šฐ๊ฐ€ ์กด์žฌํ•œ๋‹ค.

๐Ÿ”ด case 1 : z ์‚ผ์ดŒ์ด ๋ ˆ๋“œ  โžก ์ƒ‰์ƒ ๋ณ€ํ™˜ ( Recoloring )

    - z์˜ ๋ถ€๋ชจ์™€ z์˜ ์‚ผ์ดŒ ๋…ธ๋“œ๋ฅผ ๋ ˆ๋“œ์—์„œ ๋ธ”๋ž™์œผ๋กœ ๋ฐ”๊พธ๊ณ , z์˜ ํ• ์•„๋ฒ„์ง€ ๋…ธ๋“œ๋ฅผ ๋ธ”๋ž™์—์„œ ๋ ˆ๋“œ๋กœ ๋ฐ”๊พผ๋‹ค.
    - z์˜ ํ• ์•„๋ฒ„์ง€ ๋…ธ๋“œ์˜ ๋ถ€๋ชจ๋…ธ๋“œ๊ฐ€ ๋ ˆ๋“œ์ธ ๊ฒฝ์šฐ ์ด ๊ฒฝ์šฐ๋ฅผ ๋ฐ˜๋ณต ํ•œ๋‹ค.
    - z์˜ ๋ถ€๋ชจ๊ฐ€ ๋ธ”๋ž™์„ ๋งŒ๋‚ ๋•Œ ์ข…๋ฃŒ ๋˜๋ฉฐ, ๋ฃจํŠธ๊นŒ์ง€ ์˜ฌ๋ผ๊ฐ€๊ฒŒ ๋˜๋ฉด ๋ฃจํŠธ๋…ธ๋“œ๋ฅผ ๋ธ”๋ž™์œผ๋กœ ๋ฐ”๊พธ๊ณ  ์ข…๋ฃŒํ•œ๋‹ค. (๋ฃจํŠธ๋…ธ๋“œ๊นŒ์ง€ ์˜ฌ๋ผ๊ฐ€๊ฒŒ ๋˜๋ฉด black-height๋Š” 1 ์ฆ๊ฐ€ํ•˜๊ฒŒ ๋œ๋‹ค.)


 ๐Ÿ”ด case 2 : z์˜ ์‚ผ์ดŒ์ด ์—†๊ฑฐ๋‚˜ ๋ธ”๋ž™ โžก ํšŒ์ „ ( rotation , restructuring)

  ๐Ÿ”ธ ๋ถ€๋ชจ๋…ธ๋“œ (p[z])๊ฐ€ ํ• ์•„๋ฒ„์ง€ ๋…ธ๋“œ (p[p[z]]) ์˜ ์™ผ์ชฝ ์ž์‹์ผ๋•Œ
    โ—พ case 2-1 : z๊ฐ€ p[z]์˜ ์˜ค๋ฅธ์ชฝ ์ž์‹
      - p[z]๋ฅผ ์ค‘์‹ฌ์œผ๋กœ ์™ผ์ชฝ์œผ๋กœ ํšŒ์ „ ์‹œํ‚ค๊ณ , ์—ฌ์ „ํžˆ ๋ ˆ๋“œ ๋ธ”๋ž™ํŠธ๋ฆฌ ํŠน์„ฑ์„ ์œ„๋ฐ˜ํ•˜๋ฏ€๋กœ case 2-2๋ฅผ ์ˆ˜ํ–‰ํ•œ๋‹ค.

    โ—พ case 2-2 : z๊ฐ€ p[z]์˜ ์™ผ์ชฝ ์ž์‹
      - p[p[z]]๋ฅผ ์ค‘์‹ฌ์œผ๋กœ ์˜ค๋ฅธ์ชฝ ํšŒ์ „ ์‹œํ‚ค๊ณ , p[z]์™€ p[p[z]]์˜ ์ƒ‰์ƒ์„ ๋ฐ”๊พผ๋‹ค.
      (๋ถ€๋ชจ๋…ธ๋“œ๋Š” ๋ธ”๋ž™์œผ๋กœ, ํ• ์•„๋ฒ„์ง€ ๋…ธ๋“œ๋Š” ๋ ˆ๋“œ๋กœ)

  ๐Ÿ”ธ ๋ถ€๋ชจ๋…ธ๋“œ (p[z])๊ฐ€ ํ• ์•„๋ฒ„์ง€ ๋…ธ๋“œ (p[p[z]]) ์˜ ์˜ค๋ฅธ์ชฝ ์ž์‹์ผ๋•Œ
    โ—พ case 2-1 : z๊ฐ€ p[z]์˜ ์™ผ์ชฝ ์ž์‹
      - p[z]๋ฅผ ์ค‘์‹ฌ์œผ๋กœ ์˜ค๋ฅธ์ชฝ์œผ๋กœ ํšŒ์ „ ์‹œํ‚ค๊ณ , ์—ฌ์ „ํžˆ ๋ ˆ๋“œ ๋ธ”๋ž™ํŠธ๋ฆฌ ํŠน์„ฑ์„ ์œ„๋ฐ˜ํ•˜๋ฏ€๋กœ case 2-2๋ฅผ ์ˆ˜ํ–‰ํ•œ๋‹ค.

    โ—พ case 2-2 : z๊ฐ€ p[z]์˜ ์˜ค๋ฅธ์ชฝ ์ž์‹
      - p[p[z]]๋ฅผ ์ค‘์‹ฌ์œผ๋กœ ์™ผ์ชฝ ํšŒ์ „ ์‹œํ‚ค๊ณ , p[z]์™€ p[p[z]]์˜ ์ƒ‰์ƒ์„ ๋ฐ”๊พผ๋‹ค.
      (๋ถ€๋ชจ๋…ธ๋“œ๋Š” ๋ธ”๋ž™์œผ๋กœ, ํ• ์•„๋ฒ„์ง€ ๋…ธ๋“œ๋Š” ๋ ˆ๋“œ๋กœ)

z๋ฅผ ํ• ์•„๋ฒ„์ง€ ๋…ธ๋“œ ( p[p[z]] )๋กœ ๋ฐ”๊ฟ”์ฃผ๊ณ  ํ• ์•„๋ฒ„์ง€์˜ ๋ถ€๋ชจ๊ฐ€ Red๊ฐ€ ์•„๋‹๋•Œ๊นŒ์ง€ ์œ„์˜ case๋ฅผ ๋ฐ˜๋ณตํ•ด์ค€๋‹ค.
<br>
  • Delete ( ์‚ญ์ œ )

BST์˜ ํŠน์„ฑ์„ ์œ ์ง€ํ•˜๋ฉด์„œ ์‚ญ์ œํ•œ ํ›„, ์‚ญ์ œํ•  ๋…ธ๋“œ์˜ ์ž์‹๋…ธ๋“œ ๊ฐœ์ˆ˜์— ๋”ฐ๋ผ rotation ๋ฐฉ๋ฒ•์ด ๋‹ฌ๋ผ์ง„๋‹ค.
๋˜ํ•œ, ์ง€์›Œ์ง„ ๋…ธ๋“œ์˜ ์ƒ‰๊น”์ด Black์ด๋ผ๋ฉด, Black-Height๊ฐ€ 1๊ฐ์†Œํ•œ ๊ฒฝ๋กœ์— black node๊ฐ€ 1๊ฐœ ์ถ”๊ฐ€๋˜๋„๋ก rotaionํ•œ๋‹ค.

NULL node(leaf node) ์—ญ์‹œ black ์ด๋‹ค.


๐Ÿ”ด case default : ์‚ญ์ œํ•  ๋…ธ๋“œ๋ฅผ z๋ผ ํ• ๋•Œ, z๊ฐ€ RED๋ผ๋ฉด ๊ทธ๋ƒฅ ์‚ญ์ œํ•˜๊ณ , (z์˜ ์ž์‹์ด ๋‘๊ฐœ์ธ ๊ฒฝ์šฐ๋Š” ์˜ค๋ฅธ์ชฝ ์ž์‹์˜ ๊ฐ€์žฅ ์ž‘์€ key์™€ key๊ฐ’์„ ๊ตํ™˜ ํ›„ z->right์˜ minimum ๋…ธ๋“œ๋ฅผ ์‚ญ์ œํ•˜๊ฒŒ ๋˜๋ฏ€๋กœ ์ด ๋…ธ๋“œ์˜ ์ƒ‰์ด RED๋ผ๋ฉด)
BLACK์ด๋ผ๋ฉด,  black-height๊ฐ€ ์•ˆ๋งž๊ฒŒ ๋˜๋ฏ€๋กœ fix up์„ ์ˆ˜ํ–‰ํ•œ๋‹ค. (์ด๋•Œ, double-black๊ฐœ๋…์ด ๋“ฑ์žฅํ•œ๋‹ค.)

์‚ญ์ œ๋„ ์‚ฝ์ž…๊ณผ ๋งˆ์ฐฌ๊ฐ€์ง€๋กœ ์‚ญ์ œํ•œ ๋…ธ๋“œ z๋Œ€์‹  ์œ„์น˜ํ•  ๋…ธ๋“œ x๊ฐ€ p[x]์˜ ์™ผ์ชฝ ์ž์‹์ธ์ง€ ์˜ค๋ฅธ์ชฝ ์ž์‹์ธ์ง€์— ๋Œ€ํ•ด ๋Œ€์นญํ•œ๋‹ค.

์‚ญ์ œํ•œ ๋…ธ๋“œ z๋Œ€์‹  ์ƒˆ๋กœ ์œ„์น˜ํ•œ ๋…ธ๋“œ๋ฅผ x, ๊ทธ ํ˜•์ œ ๋…ธ๋“œ๋ฅผ s๋ผ๊ณ  ํ• ๋•Œ,


๐Ÿ”ด case 1 : s๊ฐ€ RED์ธ ๊ฒฝ์šฐ

  ์ด๋•Œ๋Š” s์˜ ์ž์‹๋“ค์€ leafNode ์ผ ์ˆ˜ ์—†๋‹ค.(์กฐ๊ฑด 5 ์œ„๋ฐ˜) => ํ•œ๊ฐœ๋ผ๋„ leafnode์ผ ์‹œ black-heigh๊ฐ€ ๋‹ฌ๋ผ์ง€๋ฏ€๋กœ ๋ฌด์กฐ๊ฑด ๋‘๊ฐœ๋ฅผ ๊ฐ€์ง€๊ณ  ์žˆ๋‹ค.

  ๐Ÿ”ธ x๊ฐ€ ๋ถ€๋ชจ๋…ธ๋“œ p[x]์˜ ์™ผ์ชฝ ์ž์‹์ผ๋•Œ
    - s๋ฅผ BLACK์œผ๋กœ p[x]๋ฅผ RED๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.
    - p[x]๋ฅผ left-Rotate ์‹œ์ผœ์ค€๋‹ค.
    - x์˜ ์ƒˆ๋กœ์šด ํ˜•์ œ๋…ธ๋“œ๋ฅผ ๋‹ฌ์•„์ค€๋‹ค. (s = p[x]->right) ==> x์˜ ์ƒˆ๋กœ์šด ํ˜•์ œ๋…ธ๋“œ๋Š” ์›๋ž˜ s์˜ ์™ผ์ชฝ ์ž์‹๋…ธ๋“œ (left-Rotate์‹œ์ผœ์ฃผ์—ˆ๊ธฐ ๋•Œ๋ฌธ)

  ๐Ÿ”ธ x๊ฐ€ ๋ถ€๋ชจ๋…ธ๋“œ p[x]์˜ ์˜ค๋ฅธ์ชฝ ์ž์‹์ผ๋•Œ
    - s๋ฅผ BLACK์œผ๋กœ p[x]๋ฅผ RED๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.
    - p[x]๋ฅผ right-Rotate ์‹œ์ผœ์ค€๋‹ค.
    - x์˜ ์ƒˆ๋กœ์šด ํ˜•์ œ๋…ธ๋“œ๋ฅผ ๋‹ฌ์•„์ค€๋‹ค. (s = p[x]->left) ==> x์˜ ์ƒˆ๋กœ์šด ํ˜•์ œ๋…ธ๋“œ๋Š” ์›๋ž˜ s์˜ ์™ผ์ชฝ ์ž์‹๋…ธ๋“œ (left-Rotate์‹œ์ผœ์ฃผ์—ˆ๊ธฐ ๋•Œ๋ฌธ)

  ์•„์ง double-black์ด ๋‚จ์•˜๊ธฐ ๋•Œ๋ฌธ์— case 2/3/4๋ฅผ ์ง„ํ–‰ํ•œ๋‹ค.


๐Ÿ”ด case 2 :s๊ฐ€ BLACK, s์˜ ์ž์‹๋“ค๋„ BLACK์ผ๋•Œ
    - x์˜ double-blackd์„ ์ง€์šฐ๊ณ  s๋ฅผ RED๋กœ ๋ฐ”๊พผ๋‹ค.
    - p[x]๋ฅผ x๋กœ ํ•ด์„œ ๊ณ„์† ํ•œ๋‹ค.
    - ๋งŒ์•ฝ, case 1์„ ๊ฑฐ์น˜๊ณ  case 2๋กœ ์™”๋‹ค๋ฉด, p[x]๋Š” red์˜€๊ธฐ๋•Œ๋ฌธ์— ์ข…๋ฃŒ๋œ๋‹ค. ( => s์˜ ์ž์‹๋“ค์ด ๋ชจ๋‘ black์ธ ์ฑ„๋กœ ์žˆ๊ธฐ ๋•Œ๋ฌธ์— black-height๋Š” ์œ ์ง€)


๐Ÿ”ด case 3 : s๋Š” BLACK, s์˜ ์™ผ์ชฝ ์ž์‹์ด RED, ์˜ค๋ฅธ์ชฝ ์ž์‹์ด BLACK ์ธ ๊ฒฝ์šฐ

  ๐Ÿ”ธ x๊ฐ€ ๋ถ€๋ชจ๋…ธ๋“œ p[x]์˜ ์™ผ์ชฝ ์ž์‹์ผ๋•Œ
    - s๋ฅผ RED, s์˜ ์™ผ์ชฝ ์ž์‹์„ BLACK์œผ๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.
    - s๋ฅผ ์ค‘์‹ฌ์œผ๋กœ right-Rotate ์‹œ์ผœ์ค€๋‹ค.
    - x์˜ ์ƒˆ๋กœ์šด ํ˜•์ œ๋…ธ๋“œ๋ฅผ ๋‹ฌ์•„์ค€๋‹ค. ( s = p[x]->right)

  ๐Ÿ”ธ x๊ฐ€ ๋ถ€๋ชจ๋…ธ๋“œ p[x]์˜ ์˜ค๋ฅธ์ชฝ ์ž์‹์ผ๋•Œ
    - s๋ฅผ RED, s์˜ ์™ผ์ชฝ ์ž์‹์„ BLACK์œผ๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.
    - s๋ฅผ ์ค‘์‹ฌ์œผ๋กœ left-Rotate ์‹œ์ผœ์ค€๋‹ค.
    - x์˜ ์ƒˆ๋กœ์šด ํ˜•์ œ๋…ธ๋“œ๋ฅผ ๋‹ฌ์•„์ค€๋‹ค. ( s = p[x]->left)

  case 3์˜ ๊ฒฝ์šฐ๋Š” ์œ„์˜ ๊ณผ์ •์„ ๋๋‚ด๊ณ  case 4๋ฅผ ์ด์–ด์„œ ์ˆ˜ํ–‰ํ•œ๋‹ค.


๐Ÿ”ด case 4 : s๋Š” BLACK, s์˜ ์˜ค๋ฅธ์ชฝ ์ž์‹์ด RED์ธ ๊ฒฝ์šฐ

  ๐Ÿ”ธ x๊ฐ€ ๋ถ€๋ชจ๋…ธ๋“œ p[x]์˜ ์™ผ์ชฝ ์ž์‹์ผ๋•Œ
    - s์˜ ์ƒ‰์„ p[x]์˜ ์ƒ‰์œผ๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.
    - p[x]์˜ ์ƒ‰์„ BLACK, s์˜ ์˜ค๋ฅธ์ชฝ ์ž์‹์„ BLACK์œผ๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.
    - p[x]์— ๋Œ€ํ•ด์„œ left-rotate๋ฅผ ์‹œ์ผœ์ค€๋‹ค.
    - x์˜ double-black์„ ์ œ๊ฑฐํ•˜๊ณ  ์ข…๋ฃŒํ•œ๋‹ค.

  ๐Ÿ”ธ x๊ฐ€ ๋ถ€๋ชจ๋…ธ๋“œ p[x]์˜ ์˜ค๋ฅธ์ชฝ ์ž์‹์ผ๋•Œ
    - s์˜ ์ƒ‰์„ p[x]์˜ ์ƒ‰์œผ๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.
    - p[x]์˜ ์ƒ‰์„ BLACK, s์˜ ์™ผ์ชฝ ์ž์‹์„ BLACK์œผ๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.
    - p[x]์— ๋Œ€ํ•ด์„œ right-rotate๋ฅผ ์‹œ์ผœ์ค€๋‹ค.
    - x์˜ double-black์„ ์ œ๊ฑฐํ•˜๊ณ  ์ข…๋ฃŒํ•œ๋‹ค.

x๊ฐ€ root์ด๊ฑฐ๋‚˜ double black์ด ๊นจ์งˆ๋•Œ๊นŒ์ง€ ๋ฐ˜๋ณตํ•ด์ค€ ํ›„, x๋ฅผ black์œผ๋กœ ๋ฐ”๊ฟ”์ค€๋‹ค.

  • Search ( ํƒ์ƒ‰ )

Red Black Tree๋Š” BST์˜ ์ผ์ข…์ด๊ธฐ ๋•Œ๋ฌธ์— ํƒ์ƒ‰์˜ ๋ฐฅ๋ฒ•์€ ์ผ๋ฐ˜์ ์ธ Bianry Tree์˜ ํƒ์ƒ‰ ๋ฐฉ๋ฒ•๊ณผ ๋‹ค๋ฅด์ง€ ์•Š๋‹ค.

์‹œ๊ฐ„ ๋ณต์žก๋„

์ผ๋ฐ˜ BST์˜ skewdํ•œ ๊ฒฝ์šฐ๋ฅผ balancing๊ธฐ๋ฒ•์„ ํ†ตํ•ด balancedํ•œ tree๋ฅผ ๋งŒ๋“ค์—ˆ์œผ๋ฏ€๋กœ ํƒ์ƒ‰๊ณผ์ •์€ ์›ํ•˜๋Š” ๋Œ€๋กœ O(lgn)์ด ๋‚˜์˜จ๋‹ค. ์‚ฝ์ž…์€ ์ผ๋ฐ˜ BST์—์„œ ์ตœ๋Œ€ 2๋ฒˆ์˜ rotate๊ณผ์ •๊ณผ ์ƒ‰ ๋ณ€ํ™˜์ด ์ถ”๊ฐ€ ๋˜์—ˆ๋Š” ๋ฐ, rotate๊ณผ์ •์€ ํฌ์ธํ„ฐ๋ณ€์ˆ˜๋ฅผ ๊ตํ™˜ํ•ด์ฃผ๋Š” ๊ฒƒ์ด๋ฏ€๋กœ O(1)์˜ ์‹œ๊ฐ„ ๋ณต์žก๋„์™€ ์ƒ‰๋ณ€ํ™˜๋„ ๋‹จ์ˆœํ•œ ๋ณ€์ˆ˜๊ฐ’ ๋ณ€๊ฒฝ์ด๋ฏ€๋กœ O(1)์˜ ์ƒ‰ ๋ณ€ํ™˜์ด O(lgn)๋ฒˆ ์ผ์–ด๋‚˜๊ธฐ ๋•Œ๋ฌธ์—, O(lgn)์„ ๊ฐ–๋Š”๋‹ค. ์‚ญ์ œ๋„ ์‚ฝ์ž…๊ณผ ๋™์ผํ•œ ์ด์œ ์ด๋ฉฐ, rotate๊ณผ์ •์€ ์ตœ๋Œ€ 3๋ฒˆ์ด O(lgn)๋ฒˆ ์ผ์–ด๋‚˜๊ธฐ ๋•Œ๋ฌธ์— O(lgn)์ด ๋‚˜์˜จ๋‹ค.

Previousํž™Nextstack-queue

Last updated 3 years ago

์ฝ”๋“œ ๋ณด๊ธฐ(c++)