[백준|파이썬] 13700: 완전 범죄 (실버1)
문제 https://www.acmicpc.net/problem/13700 13700번: 완전 범죄 첫째 줄에 N, S, D, F, B, K가 주어지고, K > 0인 경우에는 둘째 줄에 경찰서의 위치 l1, l2, …, lK가 주어진다. (1 ≤ S, D ≤ N ≤ 100000, 0 ≤ F, B ≤ 100000, 0 ≤ K ≤ N/2, S ≠ D ≠ l) www.acmicpc.net 🐍파이썬 import sys from collections import deque def bfs(cnt, x): queue = deque() queue.append((cnt, x))#(이동횟수, 좌표x) while queue: cnt, x = queue.popleft() dx = [x-b, x+f]#뒤로 이동한 좌표, 앞으로 ..
2023. 4. 11.
[백준|파이썬] 4963: 섬의 개수 (실버2)
문제 https://www.acmicpc.net/problem/4963 4963번: 섬의 개수 입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스의 첫째 줄에는 지도의 너비 w와 높이 h가 주어진다. w와 h는 50보다 작거나 같은 양의 정수이다. 둘째 줄부터 h개 줄에는 지도 www.acmicpc.net 🐍파이썬 import sys from collections import deque #상하좌우, 대각선 모두 방문하기 위해 좌표설정 dy = [-1, 1, 0, 0, -1, 1, -1, 1] dx = [0, 0, -1, 1, 1, 1, -1, -1] def bfs(x, y): queue = deque() queue.append((x, y)) while queue: x, y = queue...
2023. 4. 11.
[백준|파이썬] 25418: 정수 a를 k로 만들기 (실버3)
문제 https://www.acmicpc.net/problem/25418 25418번: 정수 a를 k로 만들기 7(A), 8(연산 1), 9(연산 1), 18(연산 2), 19(연산 1), 38(연산 2), 76(연산 2), 77(연산 1)이 최소 연산이므로 정답은 7이다. www.acmicpc.net 🐍파이썬 더보기 시간초과 코드 👉 BFS를 사용한 풀이 import sys from collections import deque a, k = map(int, sys.stdin.readline().split()) def bfs(answer, a): queue = deque() queue.append((answer, a)) while queue: if a == k: return answer answer, a ..
2023. 4. 10.