๐๋ฌธ์ ํ์ด
[Python] ๋ฐฑ์ค 18405 ๊ฒฝ์์ ์ ์ผ | BFS
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://www.acmicpc.net/problem/18405 18405๋ฒ: ๊ฒฝ์์ ์ ์ผ ์ฒซ์งธ ์ค์ ์์ฐ์ N, K๊ฐ ๊ณต๋ฐฑ์ ๊ธฐ์ค์ผ๋ก ๊ตฌ๋ถ๋์ด ์ฃผ์ด์ง๋ค. (1 ≤ N ≤ 200, 1 ≤ K ≤ 1,000) ๋์งธ ์ค๋ถํฐ N๊ฐ์ ์ค์ ๊ฑธ์ณ์ ์ํ๊ด์ ์ ๋ณด๊ฐ ์ฃผ์ด์ง๋ค. ๊ฐ ํ์ N๊ฐ์ ์์๋ก ๊ตฌ์ฑ๋๋ฉฐ, ํด๋น ์์น www.acmicpc.net ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ - ํน์ ์์น๋ฅผ ์ค์ฌ์ผ๋ก ์ํ์ข์ฐ ๋ป์ด๊ฐ๋ฏ๋ก BFS๊ฐ ์ ์ - ์ซ์๊ฐ ์์ ๋ฐ์ด๋ฌ์ค๊ฐ ์ฐ์ ๋์ด์ผ ํ๋ฏ๋ก ๋ฆฌ์คํธ๋ก ๋ฐ์ ์ ๋ ฌ ํ ํ๋ก ์ ํํ๋ค! - ํ์ ๊ฐ์ด ์์ด์ง ๋๊น์ง ๊บผ๋ด ์ํ์ข์ฐ์ ๊ฐ ๊ฐ์ด ๋ค์ ํ์ ๋ฃ๋ ์กฐ๊ฑด์ ๋ถํฉํ๋์ง ํ์ธํ๋ค. - ํ์์ ๊บผ๋ธ ๊ฐ์ ์๊ฐ์ด S์ ๊ฐ๋ค๋ฉด ์ข ๋ฃ - X-1 ํ ..
[Python] ๋ฐฑ์ค 14502 ์ฐ๊ตฌ์ | BFS
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://www.acmicpc.net/problem/14502 14502๋ฒ: ์ฐ๊ตฌ์ ์ธ์ฒด์ ์น๋ช ์ ์ธ ๋ฐ์ด๋ฌ์ค๋ฅผ ์ฐ๊ตฌํ๋ ์ฐ๊ตฌ์์์ ๋ฐ์ด๋ฌ์ค๊ฐ ์ ์ถ๋์๋ค. ๋คํํ ๋ฐ์ด๋ฌ์ค๋ ์์ง ํผ์ง์ง ์์๊ณ , ๋ฐ์ด๋ฌ์ค์ ํ์ฐ์ ๋ง๊ธฐ ์ํด์ ์ฐ๊ตฌ์์ ๋ฒฝ์ ์ธ์ฐ๋ ค๊ณ ํ๋ค. ์ฐ๊ตฌ์๋ ํฌ www.acmicpc.net ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ - 0์ธ ๊ฐ์ ๋ชจ๋ ์์น๋ฅผ ๋ฆฌ์คํธ (blank)์ ๋ฃ์ด์ cominations ๋ชจ๋์ ์ฌ์ฉํด 3๊ฐ ์์น ๋๋ค ์ถ์ถ(nCr) - ๋ฒ ์ด์ค๊ฐ ๋๋ ๊ธฐ์กด ์ ๋ณด์ ํด๋น ํ๋ 3๊ฐ์ ์์น๋ฅผ 1๋ก ์ค์ ํ๊ณ check ํจ์ ํธ์ถ - check ํจ์ ~ BFS๋ฅผ ์ํ ํ๋ฅผ ์ ์ธํ์ฌ ๊ฐ์ด 2์ธ ์์น๋ฅผ ๋ฃ๋๋ค. ~ ํ์ ๊ฐ์ ํ๋์ฉ ๊บผ๋ด ํด๋น ํ๋ ์์น์์ ์, ..
[Python] ํ๋ก๊ทธ๋๋จธ์ค ๋ฌธ์์ด ์์ถ | 2020 KAKAO BLIND RECRUITMENT
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://school.programmers.co.kr/learn/courses/30/lessons/60057 ํ๋ก๊ทธ๋๋จธ์ค ์ฝ๋ ์ค์ฌ์ ๊ฐ๋ฐ์ ์ฑ์ฉ. ์คํ ๊ธฐ๋ฐ์ ํฌ์ง์ ๋งค์นญ. ํ๋ก๊ทธ๋๋จธ์ค์ ๊ฐ๋ฐ์ ๋ง์ถคํ ํ๋กํ์ ๋ฑ๋กํ๊ณ , ๋์ ๊ธฐ์ ๊ถํฉ์ด ์ ๋ง๋ ๊ธฐ์ ๋ค์ ๋งค์นญ ๋ฐ์ผ์ธ์. programmers.co.kr ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ [Python] 2, 4, 7, 17, 18, 20 ์คํจ ํด๊ฒฐ ๋ฐฉ์ ๋ค๋ฅธ ๋ถ์ ํ์ด๋ฅผ ๋ณด๊ณ ์ฐธ๊ณ ํ์ฌ ๊ณต์ ํฉ๋๋ค ๋ณธ์ธ์ ๋ฐ๋ณต ๋ฐ์์ด 1์ด๋ผ๋ ์ ๋ถ ๋ฌธ์์ด์ ํฌํจํ์ฌ ์ดํ '1'์ ์ ๊ฑฐํ๋ ๋ฐฉ์์ผ๋ก ์งํํ์ต๋๋ค. ์ด๋ 2์๋ฆฌ ์ด์์ ์นด์ด๋๊ฐ ๋ฐ์ํ๋ฉด ๋ฌธ์ ๊ฐ ๋ฉ๋๋ค. '10' -> '0' '11' -> '' '12' -> '2' ... ..
[Python] ํ๋ก๊ทธ๋๋จธ์ค ๋ฌด์ง์ ๋จน๋ฐฉ ๋ผ์ด๋ธ | Heap(ํ) | 2019 KAKAO BLIND RECRUITMENT
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://school.programmers.co.kr/learn/courses/30/lessons/42891 ํ๋ก๊ทธ๋๋จธ์ค ์ฝ๋ ์ค์ฌ์ ๊ฐ๋ฐ์ ์ฑ์ฉ. ์คํ ๊ธฐ๋ฐ์ ํฌ์ง์ ๋งค์นญ. ํ๋ก๊ทธ๋๋จธ์ค์ ๊ฐ๋ฐ์ ๋ง์ถคํ ํ๋กํ์ ๋ฑ๋กํ๊ณ , ๋์ ๊ธฐ์ ๊ถํฉ์ด ์ ๋ง๋ ๊ธฐ์ ๋ค์ ๋งค์นญ ๋ฐ์ผ์ธ์. programmers.co.kr ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ - ๊ฐ์ฅ ์์ ์๊ฐ์ด ๊ฑธ๋ฆฌ๋ ์์ ๋ถํฐ ์ฒ๋ฆฌํ๋ค. (heapq ์ฌ์ฉ) - ๋ง์ฝ ๋ชจ๋ ์์์ ๊ฐ์ ๋ณด๋ค k๊ฐ ํฌ๋ค๋ฉด ๋ชจ๋ ์์์ ๋จน๊ณ ๋ ์๊ฐ์ด ๋จ๋ ๊ฒ์ด๋ฏ๋ก -1 ๋ฐํ - ํ๋ฒ์ ๋กํ ์ด์ ์ ์ํด ํ์ํ ์์ ๊ฐ์๋, 0์ด ์๋ ์์์ ์์ด๋ค.(length) - (๋ค์ ์ต์ ์์ ๊ฐ์) - (์ด์ ์ ์ฒ๋ฆฌํ ์์ ๊ฐ์) = ํ์ฌ ์ฒ๋ฆฌํด์ผ..
[Python] ๋ฐฑ์ค 4485 ๋ น์ ์ท ์ ์ ์ ๊ฐ ์ ค๋ค์ง? | ๋ค์ต์คํธ๋ผ
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://www.acmicpc.net/problem/4485 4485๋ฒ: ๋ น์ ์ท ์ ์ ์ ๊ฐ ์ ค๋ค์ง? ์ ค๋ค์ ์ ์ค ๊ฒ์์์ ํํ์ ๋จ์๋ ๋ฃจํผ(rupee)๋ค. ๊ทธ๋ฐ๋ฐ ๊ฐํน '๋๋๋ฃจํผ'๋ผ ๋ถ๋ฆฌ๋ ๊ฒ์ ์ ๋ฃจํผ๋ ์กด์ฌํ๋๋ฐ, ์ด๊ฑธ ํ๋ํ๋ฉด ์คํ๋ ค ์์งํ ๋ฃจํผ๊ฐ ๊ฐ์ํ๊ฒ ๋๋ค! ์ ค๋ค์ ์ ์ค ์๋ฆฌ์ฆ์ ์ฃผ www.acmicpc.net ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ - ๋ค์ต์คํธ๋ผ๋ฅผ ์ด์ฉํ์ฌ ๊ฐ ์์น๋ณ (0, 0)์์ ์ต์ ๋น์ฉ์ ๊ณ์ฐ - dr, dc : ๊ฐ ์์น์์ ์๋, ์, ์ค๋ฅธ์ชฝ, ์ผ์ชฝ ์์น๋ฅผ ๋ฐฉ๋ฌธ ํ๊ธฐ ์ํ ๋ฐฉํฅํค - graph : ๊ฐ ์์น ๋ฐฉ๋ฌธ์ ์ํด ํ์ํ ๋น์ฉ - distance : ๊ฐ ์์น์์ (0, 0)๊น์ง ๊ฐ๊ธฐ์ํ ์ต์ ๋น์ฉ, ์ด๊ธฐ๋ ๋ฌดํ์ ์์ฑ ์ฝ๋ imp..
[Python] ๋ฐฑ์ค 1504 ํน์ ํ ์ต๋จ ๊ฒฝ๋ก | ๋ค์ต์คํธ๋ผ
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://www.acmicpc.net/problem/1504 1504๋ฒ: ํน์ ํ ์ต๋จ ๊ฒฝ๋ก ์ฒซ์งธ ์ค์ ์ ์ ์ ๊ฐ์ N๊ณผ ๊ฐ์ ์ ๊ฐ์ E๊ฐ ์ฃผ์ด์ง๋ค. (2 ≤ N ≤ 800, 0 ≤ E ≤ 200,000) ๋์งธ ์ค๋ถํฐ E๊ฐ์ ์ค์ ๊ฑธ์ณ์ ์ธ ๊ฐ์ ์ ์ a, b, c๊ฐ ์ฃผ์ด์ง๋๋ฐ, a๋ฒ ์ ์ ์์ b๋ฒ ์ ์ ๊น์ง ์๋ฐฉํฅ ๊ธธ์ด ์กด www.acmicpc.net ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ - v1 -> v2 ์์ ๋๋ v2 -> v1 ์์ ๊ฐ๊ฐ์ ๊ฑฐ๋ฆฌ๋ฅผ ๊ตฌํ์ฌ ์์ ๊ฐ์ ์ถ๋ ฅํ๋ค. (2๋ฒ์ ๋ค์ต์คํธ๋ผ) - ๊ฒฝ๋ก๊ฐ ์๋ ๊ฒฝ์ฐ(๊ฒฐ๊ณผ ๊ฐ์ด INF๋ณด๋ค ํฌ๊ฑฐ๋ ๊ฐ์ ๊ฒฝ์ฐ) -1์ ์ถ๋ ฅ ์์ธํ ๋ด์ฉ์ ์ฝ๋ ์ฃผ์ ์ฐธ๊ณ ์์ฑ ์ฝ๋ import sys import heapq input =..
[Python] ๋ฐฑ์ค 13549 ์จ๋ฐ๊ผญ์ง 3 | ๋ค์ต์คํธ๋ผ
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://www.acmicpc.net/problem/13549 13549๋ฒ: ์จ๋ฐ๊ผญ์ง 3 ์๋น์ด๋ ๋์๊ณผ ์จ๋ฐ๊ผญ์ง์ ํ๊ณ ์๋ค. ์๋น์ด๋ ํ์ฌ ์ N(0 ≤ N ≤ 100,000)์ ์๊ณ , ๋์์ ์ K(0 ≤ K ≤ 100,000)์ ์๋ค. ์๋น์ด๋ ๊ฑท๊ฑฐ๋ ์๊ฐ์ด๋์ ํ ์ ์๋ค. ๋ง์ฝ, ์๋น์ด์ ์์น๊ฐ X์ผ www.acmicpc.net ์์ฑ ์ฝ๋ import heapq INF = int(1e9) N, K = map(int, input().split()) # ์์ ์์น, ๋์ฐฉ ์์น distance = [INF]*100001 # 100001๊ฐ์ ๋จ์ด์ง ๊ฑฐ๋ฆฌ def dijkstra(start): # ๋ค์ต์คํธ๋ผ distance[start] = 0 # ์์..
[Python] ๋ฐฑ์ค 1916 ์ต์๋น์ฉ ๊ตฌํ๊ธฐ | ๋ค์ต์คํธ๋ผ | ์๊ฐ์ด๊ณผ
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://www.acmicpc.net/problem/1916 1916๋ฒ: ์ต์๋น์ฉ ๊ตฌํ๊ธฐ ์ฒซ์งธ ์ค์ ๋์์ ๊ฐ์ N(1 ≤ N ≤ 1,000)์ด ์ฃผ์ด์ง๊ณ ๋์งธ ์ค์๋ ๋ฒ์ค์ ๊ฐ์ M(1 ≤ M ≤ 100,000)์ด ์ฃผ์ด์ง๋ค. ๊ทธ๋ฆฌ๊ณ ์ ์งธ ์ค๋ถํฐ M+2์ค๊น์ง ๋ค์๊ณผ ๊ฐ์ ๋ฒ์ค์ ์ ๋ณด๊ฐ ์ฃผ์ด์ง๋ค. ๋จผ์ ์ฒ์์๋ ๊ทธ www.acmicpc.net ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ - ๋ฐ์ ์ ๋ ฅ์ด ๋ง์ผ๋ฏ๋ก sys.stdin.realine ์ ์ฌ์ฉํ๋ค. (์๊ฐ ์ด๊ณผ ํด๊ฒฐ) - ์ ํ์ ์ธ ๋ค์ต์คํธ๋ผ ๋ฌธ์ ์ ํ์ด๋ค - ์ฐ์ ์์ ํ(์ต์ํ)๋ฅผ ์ฌ์ฉํ์ฌ ์ต์ ๊ฑฐ๋ฆฌ ๋ ธ๋๋ฅผ ์ ํ - distance : start ๋ ธ๋๋ก๋ถํฐ ๊ฐ ๋ ธ๋์ ๊ฑฐ๋ฆฌ๋ฅผ ์ ์ฅ (INF ๋ก ์ด๊ธฐํ) - graph : ๊ฐ ..
[Python] ํ๋ก๊ทธ๋๋จธ์ค ๊ฐ์ฅ ๋จผ ๋ ธ๋ | BFS | ๋ค์ต์คํธ๋ผ
~๋ชฉ์ฐจ~ ๋ฌธ์ ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ ์์ฑ ์ฝ๋ ๋ฌธ์ https://school.programmers.co.kr/learn/courses/30/lessons/49189 ํ๋ก๊ทธ๋๋จธ์ค ์ฝ๋ ์ค์ฌ์ ๊ฐ๋ฐ์ ์ฑ์ฉ. ์คํ ๊ธฐ๋ฐ์ ํฌ์ง์ ๋งค์นญ. ํ๋ก๊ทธ๋๋จธ์ค์ ๊ฐ๋ฐ์ ๋ง์ถคํ ํ๋กํ์ ๋ฑ๋กํ๊ณ , ๋์ ๊ธฐ์ ๊ถํฉ์ด ์ ๋ง๋ ๊ธฐ์ ๋ค์ ๋งค์นญ ๋ฐ์ผ์ธ์. programmers.co.kr ๋ฌธ์ ํด๊ฒฐ ํฌ์ธํธ - BFS์ ๋ค์ต์คํธ๋ผ ์๊ณ ๋ฆฌ์ฆ ๋ ๊ฐ์ง ํ์ด ๋ฐฉ์์ผ๋ก ํด๊ฒฐ (DFS๋ ๊ฐ๋ฅํ๋ python์ DFS ํจ์จ์ด ์ข์ง ๋ชป ํจ) ์์ธํ ์ค๋ช ์ ์ฃผ์ ์ฐธ๊ณ ์์ฑ ์ฝ๋ BFS ํ์ด from collections import deque def solution(n, edge): que = deque() # BFS๋ฅผ ์ํ ํ graph = [[]..