๐Ÿฅ•
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
  • Disjoint Set
  • Union-Find
  • ๊ตฌํ˜„ ๋ฐฉ๋ฒ•
  • ์‹œ๊ฐ„ ๋ณต์žก๋„
  • ๋ฌธ์ œ์ 
  • path compression (๊ฒฝ๋กœ ์••์ถ•)
  • union by rank
  • ๋‘ ๊ธฐ๋ฒ•์„ ์ ์šฉ ํ›„ ์‹œ๊ฐ„ ๋ณต์žก๋„
  • ํ™œ์šฉ
  1. ์•Œ๊ณ ๋ฆฌ์ฆ˜

DisjointSet-unionFind

Disjoint Set

๋ฒˆ์—ญํ•˜๋ฉด ์„œ๋กœ์†Œ ์ง‘ํ•ฉ์œผ๋กœ ์„œ๋กœ ์ค‘๋ณต ๋˜์ง€ ์•Š๋Š” ๋ถ€๋ถ„ ์ง‘ํ•ฉ๋“ค๋กœ ์ด๋ฃจ์–ด์ง„ ์ง‘ํ•ฉ(set).

ํ•œ๋งˆ๋””๋กœ ๊ต์ง‘ํ•ฉ์ด ์กด์žฌ ํ•˜์ง€ ์•Š๋Š” ๋ถ€๋ถ„์ง‘ํ•ฉ๋“ค๋กœ ์ด๋ฃจ์–ด์ง„ ์ง‘ํ•ฉ.

Union-Find

Union : ๋‘๊ฐœ์˜ ์ง‘ํ•ฉ์„ ํ•˜๋‚˜์˜ ์ง‘ํ•ฉ์œผ๋กœ ํ•ฉ์น˜๋Š” ๊ฒƒ.

Find : ์–ด๋–ค ์›์†Œ๊ฐ€ ์ฃผ์–ด์กŒ์„ ๋•Œ ์ด ์›์†Œ๊ฐ€ ์†ํ•œ ์ง‘ํ•ฉ์„ ๋ฐ˜ํ™˜ํ•˜๋Š”(์ฐพ๋Š”) ๊ฒƒ.

์ง‘ํ•ฉ๋“ค์„ tree๊ตฌ์กฐ๋กœ ๋‚˜ํƒ€๋‚ด์–ด ํ•ด๋‹น์›์†Œ๊ฐ€ ์–ด๋–ค ์ง‘ํ•ฉ์— ์†ํ•˜๋Š”์ง€ ํŒ๋‹จํ• ๋•Œ ๊ฐ ์ง‘ํ•ฉ์˜ ๋Œ€ํ‘œ๊ฐ’(root)์„ ์ด์šฉํ•ด์„œ ์ง‘ํ•ฉ์ด ๊ฐ™์€์ง€๋ฅผ ๋น„๊ต.

๊ตฌํ˜„ ๋ฐฉ๋ฒ•

  • ์—ฐ๊ฒฐ๋ฆฌ์ŠคํŠธ

typedef struct node{
    int data;
    struct node* parent;
    struct node* next;
}node;

void MakeSet(node* p,int x){
     p->data = x;
     p->parent = p;//์ฒ˜์Œ์€ ๋‹ค ์›์†Œ๊ฐ€ ํ•˜๋‚˜์”ฉ์žˆ๋Š” ์ง‘ํ•ฉ์ด๋ฏ€๋กœ ์ž๊ธฐ ์ž์‹ ์ด root
     p->next=null;
}

void Find(node* p,int x){
    if(p->parent->data == x) return x;  //root๊ฐ’์ด ์ž๊ธฐ ์ž์‹ ์ด๋ผ๋ฉด ์ง‘ํ•ฉ์˜ ๋Œ€ํ‘œ๊ฐ’
    else return Find(p->parent,x);  //์žฌ๊ท€์ ์œผ๋กœ ์ง‘ํ•ฉ ๋Œ€ํ‘œ๊ฐ’ ์ฐพ๊ธฐ
}

void Union(node* p1,node* p2,int x,int y){
    x = Find(p1,x);
    y = Find(p2,y);
    p1->next = p2;
    p2->parent = p1;
}

  • Disjoint Set Forest ( Tree )

int root[n];

void MakeSet(int x){
     root[x] = x;    //์ฒ˜์Œ์€ ๋‹ค ์›์†Œ๊ฐ€ ํ•˜๋‚˜์”ฉ์žˆ๋Š” ์ง‘ํ•ฉ์ด๋ฏ€๋กœ ์ž๊ธฐ ์ž์‹ ์ด root
}

void Find(int x){
    if(root[x] == x) return x;  //root๊ฐ’์ด ์ž๊ธฐ ์ž์‹ ์ด๋ผ๋ฉด ์ง‘ํ•ฉ์˜ ๋Œ€ํ‘œ๊ฐ’
    else return Find(root[x]);  //์žฌ๊ท€์ ์œผ๋กœ ์ง‘ํ•ฉ ๋Œ€ํ‘œ๊ฐ’ ์ฐพ๊ธฐ
}

void Union(int x,int y){
    x = Find(x);
    y = Find(y);
    root[y] = x;
}

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

์—ฐ๊ฒฐ๋ฆฌ์ŠคํŠธ๋กœ ๊ตฌํ˜„์‹œ O(nlgn)์˜ ์‹œ๊ฐ„์„ ๊ฐ–์œผ๋ฉฐ Tree๋กœ ๊ตฌํ˜„ํ•ด๋„ ๋ถˆ๊ท ํ˜•ํ•œ ํŠธ๋ฆฌ (์˜ˆ : skewd tree)์™€ ๊ฐ™๊ฒŒ ๋˜๋ฉด ์—ฐ๊ฒฐ๋ฆฌ์ŠคํŠธ์™€ ๋‹ค๋ฅผ ๊ฒƒ์ด ์—†์–ด์ง„๋‹ค.

๋ฌธ์ œ์ 

find์‹œ์— ์žฌ๊ท€์ ์œผ๋กœ ์ฐพ๊ธฐ ๋•Œ๋ฌธ์— ๋งŒ์•ฝ์— set์˜ tree๊ตฌ์กฐ๊ฐ€ ์„ ํ˜•์ ์ธ ํ˜•ํƒœ๋ผ๊ณ  ํ•œ๋‹ค๋ฉด ์ตœ์•…์˜ ๊ฒฝ์šฐ๋กœ O(n)๋งŒํผ์˜ ์‹œ๊ฐ„์ด ์†Œ์š” ๋˜๊ฒŒ ๋œ๋‹ค.

โžก path compression (๊ฒฝ๋กœ ์••์ถ•)๊ธฐ๋ฒ• ์‚ฌ์šฉ

๋˜ํ•œ, union์‹œ์— ๊นŠ์ด๊ฐ€ ์ž‘์€ ํŠธ๋ฆฌ์— ๊นŠ์ด๊ฐ€ ๊นŠ์€ ํŠธ๋ฆฌ๋ฅผ ๋ถ™์ด๊ฒŒ ๋˜๋ฉด ๊นŠ์ด๊ฐ€ ๋” ์ฆ๊ฐ€ํ•˜์—ฌ ์‹œ๊ฐ„์— ์•…์˜ํ–ฅ์„ ์ค€๋‹ค.

โžก union by rank ๊ธฐ๋ฒ• ์‚ฌ์šฉ

path compression (๊ฒฝ๋กœ ์••์ถ•)

find ์—ฐ์‚ฐ ์ˆ˜ํ–‰์‹œ๋งˆ๋‹ค ํŠธ๋ฆฌ์˜ ๊ตฌ์กฐ๋ฅผ ํ‰ํ‰ํ•˜๊ฒŒ ๋งŒ๋“œ๋Š” ๋ฐฉ๋ฒ•.

๊ฐ root๊ฐ’์„ ์žฌ๊ท€์ ์œผ๋กœ ๊ฐ€๋ฆฌํ‚ค๋Š” ๊ฒƒ์ด ์•„๋‹Œ ํ•ด๋‹น ์ง‘ํ•ฉ์˜ ์†ํ•˜๋Š” ์›์†Œ๋Š” ๋ชจ๋‘ ๋™์ผํ•œ root๋ฅผ ๊ฐ€๋ฆฌํ‚ค๊ฒŒ ๋งŒ๋“œ๋Š” ๋ฐฉ๋ฒ•

void Find(int x){
    /*find์ˆ˜ํ–‰๋งˆ๋‹ค ํ•ด๋‹น parent๊ฐ’์„ root๋กœ ์ดˆ๊ธฐํ™”*/
    if(root[x] != x) root[x] = Find(root[x]);
    else return root[x];
}

union by rank

ํ•ญ์ƒ ๊นŠ์ด๊ฐ€ ๊นŠ์€ ํŠธ๋ฆฌ์— ์ž‘์€ ํŠธ๋ฆฌ๋ฅผ ๋ถ™์—ฌ ๊นŠ์ด๋ฅผ ์œ ์ง€ํ•˜๋Š” ๋ฐฉ๋ฒ•.

๊นŠ์ด๊ฐ€ ์„œ๋กœ ๊ฐ™์€ ํŠธ๋ฆฌ๋ผ๋ฉด, ๊นŠ์ด๋ฅผ 1์ฆ๊ฐ€ ์‹œํ‚จ๋‹ค.

int root[n];
int rank[n];

void MakeSet(int x){
    root[x] = x;    //์ฒ˜์Œ์€ ๋‹ค ์›์†Œ๊ฐ€ ํ•˜๋‚˜์”ฉ์žˆ๋Š” ์ง‘ํ•ฉ์ด๋ฏ€๋กœ ์ž๊ธฐ ์ž์‹ ์ด root
    rank[x] = 0;    //๊นŠ์ด๋„ 0์œผ๋กœ ์ดˆ๊ธฐํ™”
}

void Union(int x,int y){
    x = Find(x);    //์ž…๋ ฅ๋ฐ›์€ x๊ฐ’์˜ root๊ฐ’์„ ์ €์žฅ
    y = Find(y);    //์ž…๋ ฅ๋ฐ›์€ y๊ฐ’์˜ root๊ฐ’์„ ์ €์žฅ

    if(x==y)  return; //root๊ฐ€ ๊ฐ™๋‹ค๋ฉด ๊ฐ™์€ ์ง‘ํ•ฉ

    if(rank[x] < rank[y])  root[x] = y; //x์˜ root๋ฅผ y๋กœ ๋ณ€๊ฒฝ
    else if(rank[x] > rank[y]) root[y]= x; //y์˜ root๋ฅผ x๋กœ ๋ณ€๊ฒฝ
    else{
        root[y] = x;
        rank[x]++;  //๊นŠ์ด๊ฐ€ ๊ฐ™๋‹ค๋ฉด x์— y๋ฅผ ๋ถ™์˜€์œผ๋ฏ€๋กœ x๊นŠ์ด ์ฆ๊ฐ€
    }

๋‘ ๊ธฐ๋ฒ•์„ ์ ์šฉ ํ›„ ์‹œ๊ฐ„ ๋ณต์žก๋„

O(lgn)

ํ™œ์šฉ

Disjoint Set ์ž๋ฃŒ๊ตฌ์กฐ๋Š” ์ง‘ํ•ฉ์˜ ๋ถ„ํ• ์„ ๋ชจ๋ธ๋ง ํ•˜๊ธฐ ๋•Œ๋ฌธ์— ๋ฌด๋ฐฉํ–ฅ ๊ทธ๋ž˜ํ”„(undirected graph) ์˜ ์—ฐ๊ฒฐ๋œ ์š”์†Œ๋“ค์„ ์ถ”์  ํ•  ์ˆ˜ ์žˆ์–ด, ์‚ฌ์ดํด์ด ๋ฐœ์ƒํ•˜๋Š”์ง€ / ๊ฐ™์€ ์š”์†Œ์— ์†ํ•˜๋Š”์ง€ ํ™•์ธ ํ•  ์ˆ˜ ์žˆ๋‹ค.

๋Œ€ํ‘œ์ ์œผ๋กœ MST๋ฅผ ์ฐพ๋Š” Kruskal ์•Œ๊ณ ๋ฆฌ์ฆ˜์— ์ด์šฉ๋œ๋‹ค.

Previous๋ณต์žก๋„ ๊ณ„์‚ฐ ( Computational Complexity )NextBellman-ford Algorithm

Last updated 3 years ago