DFS์ BFS
Last updated
ํ์ ์๊ณ ๋ฆฌ์ฆ์ ๋ํด์ ์์๋ณผ ๊ฒ์ด๋ค. ๊ทธ๋ํ์ ํ์์ ๋ชฉ์ ์ ๋ชจ๋ ์ ์ ์ 1๋ฒ์ฉ ๋ฐฉ๋ฌธ ํ๋ ๊ฒ์ด๋ค.
๊น์ด ์ฐ์ ํ์์ ํ ๋ฐฉํฅ์ผ๋ก ๊ฐ ์ ์๋ ๋งํผ ๊น์ด๊ฐ๊ธฐ๋๋ฌธ์ ๊น์ด ์ฐ์ ํ์์ด๋ค. ์ผ๋ฐ์ ์ผ๋ก DFS ํ์๋ฐฉ๋ฒ์์๋ ์คํ(stack)์๋ฃ๊ตฌ์กฐ๋ฅผ ์ด์ฉํ๋ค.
ํ์ ๊ณผ์ ์์ ๋ฌดํํ ๊น์ด๊ฐ๋ ๊ฒ์ ๋ฐฉ์งํ๊ธฐ ์ํด์ ๊น์ด์ ํ(depth bound)์ ๋๋ค. depth bound์ ๋๋ฌํ ๋๊น์ง ๋ชฉํ(๋ ธ๋)๊ฐ ๋ฐ๊ฒฌ๋์ง ์์ผ๋ฉด ๊ทธ ์ ์ ํ์ํ ๋ ธ๋์ ๋ถ๋ชจ ๋ ธ๋๋ก ๋๋์์จ๋ค. ์ด๋ ๊ฒ ๋๋์ ์ค๋ ๊ณผ์ ์ ๋ฐฑํธ๋ํน(Backtracking)์ด๋ผ ํ๋ค.
์ต๋ํ ๊น์ํ ๋ง์๊ฒ์ ํ์ํ ๋ ์ฌ์ฉํ๋ฉฐ, ์คํ์ ์ฌ์ฉํ๋ค.
์คํ์ ์ด์ฉํด ๊ฐ ์ ์๋ ๋งํผ ์ต๋ํ ๋ง์ด๊ฐ๊ณ , ๊ฐ ์ ์์ผ๋ฉด ์ด์ ์ ์ ์ผ๋ก ๋์์จ๋ค.(๋ฐฑํธ๋ํน)
๋ฐฉ๋ฌธํ ๊ณณ์ ํ์๋ฅผ ํด๋๋ค.(check[i] )
์ด๋ฏธ ๋ฐฉ๋ฌธํ ๊ณณ์ ๊ฑด๋๋๊ณ , ๊ฐ ์ ์๋ ๊ณณ์ผ๋ก ๊ฐ๋ค. ์คํ์ด ๋น์์ง ๋๊น์ง ๊ณ์ pop์ ํ๋ค. ์คํ์ด ๋น์ด์์ผ๋ฉด DFSํ์์ด ์ข ๋ฃ๋๋ค.
ํ์ฌ ๊ฒฝ๋ก์์ ๋ ธ๋๋ค๋ง ๊ธฐ์ตํ๋ฉด ๋๋ฏ๋ก ์ ์ฅ๊ณต๊ฐ์ ์์๊ฐ ๋น๊ต์ ์ ๋ค.
๋ชฉํ๋ ธ๋๊ฐ ๊น์ ๋จ๊ณ์ ์์ ๊ฒฝ์ฐ์ ํด๋ฅผ ๋นจ๋ฆฌ ๊ตฌํ ์ ์๋ค.
ํด๊ฐ ์๋ ๊ฒฝ๋ก์ ๋๋ฌด ๊น์ด ๋น ์ง๊ฒ ๋ ๊ฐ๋ฅ์ฑ์ด ์๋ค. ๋ฐ๋ผ์ ์ค์ ๊ฒฝ์ฐ์๋ ๋ฏธ๋ฆฌ ์ง์ ํ ์์์ ๊น์ด(depth bound)๊น์ง๋ง ํ์ํ๊ณ ๋ชฉํ๋ ธ๋๋ฅผ ๋ฐ๊ฒฌํ์ง ๋ชปํ๋ฉด ๋ค์ ๊ฒฝ๋ก๋ฅผ ๋ฐ๋ผ ํ์ํ๋ ๊ฒ์ด ์ ์ฉํ ์ ์๋ค.
์ป์ด์ง ๊ฒฝ๋ก๊ฐ ์ต๋จ ๊ฒฝ๋ก๊ฐ ์๋ ์ ์๋ค. ๋ชฉํ๊น์ง์ ๊ฒฝ๋ก๊ฐ ์ฌ๋ฌ๊ฐ์ธ ๋ฌธ์ ์ ๋ํด์ DFS๋ ๋ชฉํ์ ๋๋ฌํ๋ฉด ํ์์ ์ข ๋ฃํ๋ฏ๋ก, ์ด๋ ์ฐพ์ ๊ฒฝ๋ก๋ ์ต์ ์ ๊ฒฝ๋ก๊ฐ ์๋ ์ ์๋ค.
๊ทธ๋ํ๊ฐ disconnected์ด๊ฑฐ๋ ํน์ ๋ฐฉํฅ ๊ทธ๋ํ๋ผ๋ฉด DFS์ ์ํด์ ๋ชจ๋ ๋ ธ๋๊ฐ ๋ฐฉ๋ฌธ๋์ง ์์ ์ ์๋ค.
dfs(x)๋ x๋ฅผ ๋ฐฉ๋ฌธํ๋ค๋ ์๋ฏธ์ด๋ค. ์ฌ๊ท ํธ์ถ์ ์ด์ฉํด์ ๊ตฌํํ ์ ์๋ค.
์๊ฐ๋ณต์ก๋ : V*O(V) = O(V^2)
ํญ์ ์๋ ๊ฐ์ ๋ง ์ ์ฅํ๋ค.
๋ชจ๋ ์ ์ ์ ํ๋ฒ์ฉ ๊ฑฐ์น๊ณ ๋ชจ๋ ๊ฐ์ ์ ํ๋ฒ์ฉ ๊ฒ์ฌํ๊ฒ ๋๋ค.
์๊ฐ๋ณต์ก๋ O(V+E)
ํ์ฌ ์ ์ ์์ ๊น์ด๊ฐ 1์ธ ์ ์ ์ ๋ชจ๋ ํ์ํ ๋ค ๊น์ด๋ฅผ ๋๋ ค๊ฐ๋ ๋ฐฉ์์ด๋ค. ๋๋น์ฐ์ ํ์์ ๋ฐฑํธ๋์ ํ์ง ์๋๋ค. ๋์ ์ ํ์ฌ ์ ์ ์์ ๊น์ด๊ฐ 1์ธ ์ ์ ์ ๋ชจ๋ ๋ฐฉ๋ฌธํด์ผํ๋ฏ๋ก ํ(queue)๋ผ๋ FIFO(First In First Out)์๋ฃ๊ตฌ์กฐ๋ฅผ ํ์ฉํด ํ์ฌ ์ ์ ์์ ๊น์ด๊ฐ 1 ๋ ๊น์ ๋ชจ๋ ์ ์ ์ ์์ฐจ์ ์ผ๋ก ํ์ ์ ์ฅํด ํ์์ ํ์ฉํ๋ค.
std::queue()
๋ฅผ ํ์ฉํ๋ ๋ฐฉ๋ฒ์ ์ตํ ํ์๊ฐ ์๋ค.
BFS๋ฅผ ํ๋ฉด์ ๊ฐ ๋ ธ๋์ ๋ํด์ ์ต๋จ ๊ฒฝ๋ก์ ๊ธธ์ด๋ฅผ ๊ตฌํ ์ ์๋ค.
L0 = {s}, s๋ ์ถ๋ฐ ๋ ธ๋
L1 = L0์ ๋ชจ๋ ์ด์ ๋ ธ๋๋ค
L2 = L1์์ ๋ชจ๋ ์ด์๋ค ์ค L0์ ์ํ์ง ์๋ ๋ ธ๋๋ค
...
LN = Ln์์ ๋ชจ๋ ์ด์๋ค ์ค Ln-1์ ์ํ์ง ์๋ ๋ ธ๋๋ค
๋ค์๊ณผ ๊ฐ์ ์์๋ก ๋ฐฉ๋ฌธํ๋ ๋ฐฉ๋ฒ์ด๋ค.
์ต๋ํ ๋๊ฒ ๊ฐ๋๊ธธ์ ํ์ํ ๋ ์ฌ์ฉํ๋ฉฐ, ํ๋ฅผ ์ฌ์ฉํ๋ค. ํ๋ฅผ ์ด์ฉํด์ ์ง๊ธ ์์น์์ ๊ฐ ์ ์๋ ๊ฒ์ ๋ชจ๋ ํ์ ๋ฃ๋ ๋ฐฉ์์ด๋ค.
BFS๋ ํ์ ๋ฃ์ ๋ ๋ฐฉ๋ฌธํ๋ค๊ณ ์ฒดํฌ(check[i])ํด์ผํ๋ค.
ํ์์ popํ ๋ ธ๋๋ค ์ค์์ ๋ฐฉ๋ฌธํ์ง ์์ ๋ชจ๋ ์ด์ ๋ ธ๋๋ฅผ ํ์ ๋ฃ์ผ๋ฉด์ ๋ฐฉ๋ฌธํ๋ค๊ณ ์ฒดํฌํด์ค๋ค.
Queue๊ฐ ๋น๋๊น์ง ์งํํด์ค๋ค.
๊ทธ๋ํ๊ฐ disconnected์ด๊ฑฐ๋ ํน์ ๋ฐฉํฅ ๊ทธ๋ํ๋ผ๋ฉด BFS์ ์ํด์ ๋ชจ๋ ๋ ธ๋๊ฐ ๋ฐฉ๋ฌธ๋์ง ์์ ์ ์๋ค.
์ ์ฒด ํ์ํ๋๋ฐ ์์ด์ ๋ฐ๋ณต๋ฌธ์ n^2๋ฒ ์คํํ๊ฒ๋๋ค.
์๊ฐ๋ณต์ก๋ O(V^2)
์ ์ฒด๋ฅผ ํ์ํ๋ ๋ฐ ์์ด์ ๋ฐ๋ณต๋ฌธ์ m๋ฒ ์คํํ๊ฒ ๋๋ค.
์ ๋ ฅ : ๋ฐฉํฅ ํน์ ๋ฌด๋ฐฉํฅ ๊ทธ๋ํ G(V,E), ๊ทธ๋ฆฌ๊ณ ์ถ๋ฐ๋ ธ๋ s
์ถ๋ ฅ : ๋ชจ๋ ๋ ธ๋ v์ ๋ํด์
d[v] = s๋ก๋ถํฐ v๊น์ง์ ์ต๋จ ๊ฒฝ๋ก์ ๊ธธ์ด(์ฃ์ง์ ์)
ฯ[v] = s๋ก๋ถํฐ v๊น์ง์ ์ต๋จ ๊ฒฝ๋ก์์์ v์ ์ง์ ๋ ธ๋(predecessor)
์๊ฐ๋ณต์ก๋ O(V+E)
DFS | BFS | |
๋์ ์๋ฆฌ | ์คํ | ํ |
๊ตฌํ ๋ฐฉ๋ฒ | ์ฌ๊ท | ํ ์๋ฃ๊ตฌ์กฐ ์ด์ฉ |
๊ทธ๋ํ๋ฅผ DFS๋ก ํ์ํ ๊ฒฐ๊ณผ์ BFS๋ก ํ์ํ ๊ฒฐ๊ณผ๋ฅผ ์ถ๋ ฅํ๋ ํ๋ก๊ทธ๋จ์ ์์ฑํ์์ค. ๋จ, ๋ฐฉ๋ฌธํ ์ ์๋ ์ ์ ์ด ์ฌ๋ฌ ๊ฐ์ธ ๊ฒฝ์ฐ์๋ ์ ์ ๋ฒํธ๊ฐ ์์ ๊ฒ์ ๋จผ์ ๋ฐฉ๋ฌธํ๊ณ , ๋ ์ด์ ๋ฐฉ๋ฌธํ ์ ์๋ ์ ์ด ์๋ ๊ฒฝ์ฐ ์ข ๋ฃํ๋ค. ์ ์ ๋ฒํธ๋ 1๋ฒ๋ถํฐ N๋ฒ๊น์ง์ด๋ค.
์ง๋ขฐ์ฐพ๊ธฐ, ๋ฟ์๋ฟ์ ๋ฑ ๊ฒ์์์ ๋ง์ด ํ์ฉ๋๋ ์๊ณ ๋ฆฌ์ฆ. ์ฌ๊ทํจ์๋ฅผ ์ด์ฉํด ๊น์ด์ฐ์ ํ์์ ๊ตฌํํ๋ค. ํ์ง๋ง ์ฌ๊ท์ ๊น์ด๊ฐ ๋๋ฌด ์ปค์ง๋ฉด runtime error๊ฐ ๋ฐ์ํ ์ ์๋ค. ๊น์ด๊ฐ ๋๋ฌด ํฌ๋ค๊ณ ํ๋จ๋๋ฉด ๋๋น์ฐ์ ํ์์ผ๋ก ์ฒ๋ฆฌํ๊ฑฐ๋ ์ฌ๊ท๋์ ์คํ์ ์ด์ฉํ๋ค.
dfsํจ์ ๋ถ๋ถ์ 4๋ฐฉํฅ ํ์์ dx,dy๋ฅผ ์ด์ฉํด ์์ฑํ ์ ์๋ค.
n*n์ฒด์ค ๋ณด๋ํ์ n๊ฐ์ queen์ ์๋ก ๊ณต๊ฒฉํ์ง ๋ชปํ๋๋ก ๋ฐฐ์นํ๋ ๋ฐฉ๋ฒ์ ์ฐพ์๋ด๋ ๋ฌธ์ . ๋๊ฐ์ ๊ฒ์ฌํ๋ฉด์ ๊ฐ์ผํ๋ ์๊ณ ๋ฆฌ์ฆ์ ์ ์ฉํ๋ค.
ํธ์ 8๋ฐฉํฅ์ผ๋ก ๋ชจ๋ ๊ณต๊ฒฉํ ์ ์๋ค.
์ฒซ ๋ฒ์งธ ํ, ์ฒซ ๋ฒ์งธ ์ด์ ํธ์ ๋๋๋ค.
๋ค์ ํ์์ ๊ฐ๋ฅํ ๊ฐ์ฅ ์ผ์ชฝ ์ด์ ํธ์ ๋๋๋ค.
n๋ฒ์งธ ์ด์ ๋ ์ด์ ํธ์ ๋์ ์ ์๋ค๋ฉด ๋ฐฑํธ๋ํ๋ค.
๋ง์ง๋ง ํ์ ํธ์ ๋์ผ๋ฉด ํ๋์ ํด๋ฅผ ๊ตฌํ ๊ฒ์ด๋ค.
๋ชจ๋ ๊ฒฝ์ฐ๋ฅผ ์กฐ์ฌํ ๋๊น์ง ๋ฐฑํธ๋ํนํด๊ฐ๋ฉฐ ํด๋ค์ ๊ตฌํ๋ค.
๊น์ด์ฐ์ ํ์์ ํ๋ฉฐ ํด๋ฅผ ๊ตฌํ ๋๋ง๋ค ์นด์ดํธํด ์ํ๋ ํด๋ฅผ ๊ตฌํ ์ ์๋ค. ์ด๊ณผ ๋๊ฐ์ ๋ง ๊ฒ์ฌํ๋ฉด ๋๋ค. ๋๊ฐ์ ์ ํ+์ด ์์น์ ์ฒดํฌํด ๊ธฐ์ธ๊ธฐ๊ฐ ์ฆ๊ฐํ๋ ๋๊ฐ์ ์์ ํธ์ ๋์ ์ ์๋์ง ์๋์ง ํ์ธํ๋ค. ๊ธฐ์ธ๊ธฐ๊ฐ ๊ฐ์ํ๋ ๋๊ฐ์ ์ ํ๊ณผ ์ด์ ์ฐจ๊ฐ ์ผ์ ํ๋ค. n+(ํ-์ด)
์ ์์น์ ์ฒดํฌ. ๋ฐฑํธ๋ ์์ ๊ฐ์ฅ ์ค์ํ ์ ์ ์ฒดํฌ๋ฐฐ์ด์ ๊ธฐ๋กํด ๋์๋ ์ฒดํฌ๋ฅผ ๋ชจ๋ ํด์ ํด์ผํ๋ค.