250x250
Rainbow๐ŸŒˆCoder
My dev Note๐Ÿ“’
Rainbow๐ŸŒˆCoder
์ „์ฒด ๋ฐฉ๋ฌธ์ž
์˜ค๋Š˜
์–ด์ œ
  • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (411)
    • ๊ณต์ง€์‚ฌํ•ญ (0)
    • Debugger (10)
      • Visual Studio Debugger (1)
      • Chrome DevTools (3)
      • Visual Studio Code Debugger (4)
      • eclipse (1)
      • intelliJ (1)
    • OOP (2)
      • OOP (2)
    • TypeScript (54)
      • ํƒ€์ž…์Šคํฌ๋ฆฝํŠธ TypeScript (54)
    • Javascript (87)
      • Javascript (45)
      • Node.js (19)
      • React (5)
      • FE ๊ฐœ๋ฐœํ™˜๊ฒฝ์„ค์ • (3)
      • React์™€ Node ๊ฐ™์ด ๋•Œ๋ ค์žก๊ธฐ (6)
      • next.js (2)
      • pixi.js (7)
    • ๋งˆํฌ์—… (23)
      • Html & Css (23)
    • C# (80)
      • C# (12)
      • ์ด๊ฒƒ์ด C#์ด๋‹ค (68)
    • C++ (30)
      • c++ (27)
      • win api (3)
    • Unity (18)
      • Unity(๊ธฐ์ดˆ) (8)
      • Unity(C#์ค‘๊ธ‰) (5)
      • ์œ ๋‹ˆํ‹ฐ ํฌํ†ค(๋„คํŠธ์›Œํฌ) (4)
      • unity c# MyCode (1)
    • Java & Spring (29)
      • Java (11)
      • ์Šคํ”„๋ง (8)
      • Java Algorithm (9)
      • Javs Data Structures (1)
    • ์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜ (15)
      • ์ž๋ฃŒ๊ตฌ์กฐ (5)
      • ์•Œ๊ณ ๋ฆฌ์ฆ˜ (10)
    • ํ˜•์ƒ๊ด€๋ฆฌ (15)
      • Git (11)
      • ์†Œ์ŠคํŠธ๋ฆฌ (3)
    • ๊ทธ๋ž˜ํ”ฝ์Šค (7)
      • WebGl (7)
    • AWS (3)
      • aws (3)
    • ๋ฆฌ๋ˆ…์Šค (5)
      • ๋ฆฌ๋ˆ…์Šค (5)
    • ์ฑ… ๋ฆฌ๋ทฐ (13)
      • ํด๋ฆฐ์ฝ”๋“œ(์ฑ…๋ฆฌ๋ทฐ) (3)
      • ์œ ์ง€๋ณด์ˆ˜๊ฐ€๋Šฅํ•œ์ฝ”๋”ฉ์˜๊ธฐ์ˆ C#ํŽธ(์ฑ…๋ฆฌ๋ทฐ) (1)
      • ๋ฆฌํŒฉํ† ๋ง(์ž๋ฐ”์Šคํฌ๋ฆฝํŠธํŒ) (9)
    • Server (2)
      • ๊ฒŒ์ž„ ์„œ๋ฒ„(๋„คํŠธ์›Œํฌ, ๋ฉ€ํ‹ฐ์“ฐ๋ ˆ๋“œ,OS) (2)
    • ์„ค๊ณ„, ์•„ํ‚คํ…์ณ (4)
    • ํŒŒ์ด์ฌ (5)
    • ๋””์ž์ธํŒจํ„ด (2)
    • mocha (2)
    • Jest (1)
    • Spine (1)
    • ์ธ๊ณต์ง€๋Šฅ (1)
      • ํ˜ผ์ž๊ณต๋ถ€ํ•˜๋Š”๋จธ์‹ ๋Ÿฌ๋‹+๋”ฅ๋Ÿฌ๋‹ (1)

๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

  • ํ™ˆ
  • ํƒœ๊ทธ
  • ๋ฐฉ๋ช…๋ก

๊ณต์ง€์‚ฌํ•ญ

์ธ๊ธฐ ๊ธ€

ํƒœ๊ทธ

  • ์ปดํฌ์ง€์…˜
  • MySQL
  • ์œ„์ž„
  • ใ…ฃใ„ท

์ตœ๊ทผ ๋Œ“๊ธ€

์ตœ๊ทผ ๊ธ€

ํ‹ฐ์Šคํ† ๋ฆฌ

hELLO ยท Designed By ์ •์ƒ์šฐ.
Rainbow๐ŸŒˆCoder

My dev Note๐Ÿ“’

์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜/์•Œ๊ณ ๋ฆฌ์ฆ˜

๊นŠ์ด ์šฐ์„  ํƒ์ƒ‰(DFS, Depth First Search), ๋„ˆ๋น„ ์šฐ์„  ํƒ์ƒ‰(BFS, Breadth First Search))

2021. 5. 16. 21:54
728x90

BFS, DFS๋ž€ ๊ทธ๋ž˜ํ”„์˜ ํƒ์ƒ‰ ๊ธฐ๋ฒ•์œผ๋กœ

๋ชฉ์ ์€ ์ž„์˜์˜ ํ•œ ์ •์ ์—์„œ ์‹œ์ž‘ํ•˜์—ฌ ๋ชจ๋“  ์ •์ ์„ ๋ฐฉ๋ฌธํ•˜๋Š” ๋ฐ ์žˆ๋‹ค.

 

๊นŠ์ด ์šฐ์„  ํƒ์ƒ‰ - DFS(Depth-first search)

์ž์‹ ๋…ธ๋“œ๋ฅผ ์šฐ์„ ์ ์œผ๋กœ ํƒ์ƒ‰

์ฆ‰, ์•„์ง ๋ฐฉ๋ฌธ๋˜์ง€ ์•Š์€ ์ธ์ ‘ ๋…ธ๋“œ(์ž์‹ ๋…ธ๋“œ)๋ฅผ ์šฐ์„ ์ ์œผ๋กœ ํƒ์ƒ‰

๊นŠ์ด ์šฐ์„  ํƒ์ƒ‰์€ ํ•œ์ชฝ๋งŒ ์ฃฝ์–ด๋ผ ํŒŒ๋‹ค๊ฐ€ ๋”์ด์ƒ ํŒ” ๊ณณ์ด ์—†์œผ๋ฉด ๋‹ค์‹œ ๋Œ์•„์™€์„œ ๋‹ค๋ฅธ ํ•œ์ชฝ์„ ์ฃฝ์–ด๋ผ ํŒŒ๋Š” ํ˜•์‹์ด๋‹ค.

๊นŠ์ด ์šฐ์„  ํƒ์ƒ‰์€ Stack์„ ํ†ตํ•ด ๊ตฌํ˜„๋œ๋‹ค.

 

๋„ˆ๋น„ ์šฐ์„  ํƒ์ƒ‰ - BFS(Breadth-first search)=๋ ˆ๋ฒจ ์ˆœํšŒ(level-order traversal)

์ฝ”๋“œ๋งํฌ : BFS ์ฝ”๋“œ (tistory.com)

๊ฐ„์„ ์˜ ๋ชจ๋“  ๊ฐ€์ค‘์น˜๊ฐ€ ๊ฐ™์„ ๋•Œ, ์ตœ๋‹จ ๊ฑฐ๋ฆฌ๋ฅผ ๊ตฌํ•˜๋Š” ์•Œ๊ณ ๋ฆฌ์ฆ˜์œผ๋กœ

์‹œ์ž‘ ์ •์ ์„ ๊ธฐ์ค€์œผ๋กœ ๊ฐ€๊นŒ์šด ์ •์ ์„ ๋จผ์ € ๋ฐฉ๋ฌธํ•œ๋‹ค.

๋ฐฉ๋ฌธ ์ˆœ์„œ๋Š” ์ตœ๋‹จ ๊ฑฐ๋ฆฌ์— ์˜ํ–ฅ์„ ๋ผ์นœ๋‹ค.

ํ˜•์ œ ๋…ธ๋“œ๋ฅผ ์šฐ์„ ์ ์œผ๋กœ ํƒ์ƒ‰

์ฆ‰, ์•„์ง ๋ฐฉ๋ฌธ๋˜์ง€ ์•Š์€ ์ด์ „ ๋…ธ๋“œ(๋ถ€๋ชจ ๋…ธ๋“œ)์˜ ์ธ์ ‘ ๋…ธ๋“œ(ํ˜„์žฌ ๋…ธ๋“œ์˜ ํ˜•์ œ ๋…ธ๋“œ)๋ฅผ ์šฐ์„ ์ ์œผ๋กœ ํƒ์ƒ‰

๋ณดํ†ต ๋„ˆ๋น„ ์šฐ์„  ํƒ์ƒ‰์€ Queue๋ฅผ ํ†ตํ•ด ๊ตฌํ˜„ํ•˜์—ฌ ์„ ์ž…์„ ์ถœ์˜ ์›์น™์œผ๋กœ ํƒ์ƒ‰ํ•œ๋‹ค.

๊ฐ ๋…ธ๋“œ๋ฅผ ๋ฐฉ๋ฌธํ•  ๋•Œ visit[y][x]=1๋กœ ๋ณ€๊ฒฝํ•ด์ค€๋‹ค๋ฉด,

visit[y][x]=1์ธ ๋…ธ๋“œ๋ฅผ ๋งŒ๋‚  ๋•Œ continue; ํ•ด์ฃผ๋Š” ๋ฐฉ์‹์œผ๋กœ ์ค‘๋ณต ๋ฐฉ๋ฌธ์„ ํšŒํ”ผํ•œ๋‹ค.

 

 

728x90

'์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜ > ์•Œ๊ณ ๋ฆฌ์ฆ˜' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[c++] ์‚ฝ์ž… ์ •๋ ฌ  (0) 2021.09.21
[c++] ๋ฒ„๋ธ”์ •๋ ฌ  (0) 2021.09.21
[c++] [์„ ํƒ ์ •๋ ฌ] ํ™œ์šฉํ•ด์„œ ๋ฐฐ์—ด ์† ์ˆซ์ž๋“ค์„ ์˜ค๋ฆ„์ฐจ์ˆœ์œผ๋กœ ๋ฐ”๊พธ๊ธฐ  (0) 2021.09.20
c++ ๋ฐฐ์—ด ์˜ค๋ฆ„์ฐจ์ˆœ ๋‚ด๋ฆผ์ฐจ์ˆœ ๊ตฌํ˜„  (0) 2021.09.20
2. [c++] ํŠน์ •๊ฐ’ ์ดํ•˜์˜ ์ˆ˜ ์ค‘์—์„œ ๊ฐ€์žฅ ํฐ 2์˜ ๊ฑฐ๋“ญ์ œ๊ณฑ๋งŒ ๋ฐ˜ํ™˜ํ•˜๋Š” ํ•จ์ˆ˜๋งŒ๋“ค๊ธฐ  (0) 2021.09.18
    '์ž๋ฃŒ๊ตฌ์กฐ์™€ ์•Œ๊ณ ๋ฆฌ์ฆ˜/์•Œ๊ณ ๋ฆฌ์ฆ˜' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
    • [c++] ๋ฒ„๋ธ”์ •๋ ฌ
    • [c++] [์„ ํƒ ์ •๋ ฌ] ํ™œ์šฉํ•ด์„œ ๋ฐฐ์—ด ์† ์ˆซ์ž๋“ค์„ ์˜ค๋ฆ„์ฐจ์ˆœ์œผ๋กœ ๋ฐ”๊พธ๊ธฐ
    • c++ ๋ฐฐ์—ด ์˜ค๋ฆ„์ฐจ์ˆœ ๋‚ด๋ฆผ์ฐจ์ˆœ ๊ตฌํ˜„
    • 2. [c++] ํŠน์ •๊ฐ’ ์ดํ•˜์˜ ์ˆ˜ ์ค‘์—์„œ ๊ฐ€์žฅ ํฐ 2์˜ ๊ฑฐ๋“ญ์ œ๊ณฑ๋งŒ ๋ฐ˜ํ™˜ํ•˜๋Š” ํ•จ์ˆ˜๋งŒ๋“ค๊ธฐ
    Rainbow๐ŸŒˆCoder
    Rainbow๐ŸŒˆCoder
    ๋ชฐ๋ผ๋„ ๊ฒฐ๊ตญ์€ ์•„๋Š” ๊ฐœ๋ฐœ์ž, ๊ทธ๋Ÿฐ ์‚ฌ๋žŒ์ด ๋˜๊ธฐ ์œ„ํ•œ ๋งค์ผ์˜ ํ•œ๊ฑธ์Œ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”