BFS

[Python]알고리즘/백준

[DFS/BFS/완전탐색] ★ 1707번 - 이분 그래프(BFS)

[백준] 1707번 - 이분 그래프 풀이 시간: 60분 이내 1) 문제 해결 아이디어 아이디어를 떠올리기 굉장히 어려웠던 문제다. 아이디어만 쉽게 떠올렸다면 구현하는데는 오래 걸리지 않은 문제다. 하지만 추후 복습이 필요한 문제! 일단 이분 그래프에 대해서 정확한 이해가 필요하다. 그래프의 정점의 집합을 둘로 분할하여, 각 집합에 속한 정점끼리는 서로 인접하지 않도록 분할할 수 있을 때, 그러한 그래프를 특별히 이분 그래프 (Bipartite Graph) 라 부른다. 즉, 그래프의 정점을 두가지 색으로 칠한다고 했을 때, 인접한 정점끼리는 다른 색을 가지고 있는 그래프가 이분 그래프다. 1. 시작점 삽입, 방문 처리 (시작점은 0으로 방문 처리함) 2. 인접노드들에 대해 반복 2-1. 방문하지 않은 노드..

[Python]알고리즘/백준

[DFS/BFS/완전탐색] 2589번 - 보물섬(BFS)

[백준] 2589번 - 보물섬 풀이 시간: 20분 이내 1) 문제 해결 아이디어 이 문제는 보물이 묻혀있는 두 곳 간의 최단 거리로 이동하는 시간을 문제로 BFS로 풀이가 가능하다. 일단 보물은 육지에 묻혀있을 수 있기 때문에 for문을 돌려 육지인 모든 칸에 대해서 bfs()를 호출하여 모든 경우를 검사해보아야 한다. 여기서 보물은 최단 거리로 이동한다고 가정했을 때 가장 오랜 시간이 걸리는 곳이어야 한다. 그러므로 하나의 보물이 시작점에 있다고 보면 다른 보물은 시작점에서 bfs를 했을 때 기록된 visited의 값 중 최댓값에 위치해야 한다. 두 보물 사이의 최단 거리는 (최댓값 - 1) 이므로 이 값을 리턴하고 종료한다. 그렇게 모든 육지 칸에 대해 bfs를 돌려 얻은 값들 중 최댓값이 이 문제의..

[Python]알고리즘/백준

[DFS/BFS/완전탐색] 1926번 - 그림(BFS)

[백준] 1926번 - 그림 풀이 시간: 10분 이내 아주 쉽게 해결할 수 있었던 문제이다. 그림의 개수와 그 중 가장 넓은 그림의 넓이를 출력하는 문제로 BFS, DFS로 모두 풀이가 가능한 유형이다. 하지만 다른 사람들의 DFS 풀이를 찾아봐도 시간초과나 메모리초과 문제가 다수가 발생했다. 아래 글에 따르면 DFS에서 방향벡터를 이용해 for문을 돌리지 않으면 메모리 초과가 뜨지 않았지만 이런 문제의 경우 그냥 BFS로 풀이하는 것이 좋을 듯 하다. DFS는 재귀 방식으로 수행되기 때문에 호출할 때마다 스택에 쌓여 메모리를 많이 차지하게 되고 BFS는 큐에 쌓이는 객체의 크기가 크지 않다면 훨씬 적은 비용이 발생하므로 메모리 측면에서 유리할 수 있다. 오늘의 교훈! 상황에 따라 DFS, BFS 풀이를..

[Python]알고리즘/백준

[DFS/BFS/완전탐색] 17086번 - 아기 상어2(BFS)

[백준] 17086번 - 아기 상어2 풀이 시간: 40분 이내 유사 문제: 7576번 https://hseungyeon.tistory.com/217 [DFS/BFS/완전탐색] ▲ 7576번 - 토마토 [백준] 7576번 - 토마토 풀이 시간: 40분 이내 1) 문제 해결 아이디어 토마토가 모두 익을 때까지 최소 날짜를 구하는 문제다. 익은 토마토가 상하좌우로 인접한 위치에 있는 익지 않은 토마토를 hseungyeon.tistory.com N * M의 맵에서 상어 위치 기준 둘러싼 8개의 좌표로 이동이 가능하다. 이 문제는 처음에 BFS로 풀어야 하나 싶지만 1개 이상의 상어에서 가장 멀리 떨어진 칸을 찾는 문제로 BFS로 풀어야하는 문제이다. (풀이1) 시간 초과한 코드(0인 곳에서 bfs 호출) 1) ..

[Python]알고리즘/백준

[DFS/BFS/완전탐색] 1303번 - 전쟁 - 전투(BFS/DFS)

[백준] 1303번 - 전쟁 - 전투 풀이 시간: 15~20분 이내 정석대로만 풀면 아주 쉽게 풀 수 있는 문제로 DFS, BFS 풀이가 모두 가능하다. DFS 풀이가 시간, 메모리 효율이 더 뛰어나다. (풀이1) BFS 1) 문제 해결 아이디어 2) 소스코드 from collections import deque # BFS def bfs(x, y, color): cnt = 0 # 병사 수 queue = deque() # 시작 지점 삽입, 방문 처리 queue.append((x, y)) graph[x][y] = 0 while queue: x, y = queue.popleft() cnt += 1 for i in range(4): nx = x + dx[i] ny = y + dy[i] if(0

[Python]알고리즘/백준

[DFS/BFS/완전탐색] ▲ 13913번 - 숨바꼭질 4(BFS)

[백준] 13913번 - 숨바꼭질 4 풀이 시간: 60분 이내 유사 문제: 1697번, 12851번, 13549번 https://hseungyeon.tistory.com/222 [DFS/BFS/완전탐색] 1697번 - 숨바꼭질(BFS) [백준] 1697번 - 숨바꼭질 풀이 시간: 40분 이내 1) 문제 해결 아이디어 코드를 짜는데는 10분 정도 걸렸는데 오류를 고치는데 시간을 허비했다. 이 문제 같은 경우는 수빈이와 동생의 위치가 N, K로 hseungyeon.tistory.com https://hseungyeon.tistory.com/229 [DFS/BFS/완전탐색] ★ 12851번 - 숨바꼭질 2(BFS) [백준] 12851번 - 숨바꼭질 2 풀이 시간: 60분 이내 유사문제 1697번 https:/..

[Python]알고리즘/백준

[DFS/BFS/완전탐색] ★ 13549번 - 숨바꼭질 3(BFS)

[백준] 13549번 - 숨바꼭질 3 풀이 시간: 15~20분 이내 2가지 풀이 방법이 있으나 2번 풀이가 문제를 본질적으로 이해하고 효율적으로 짠 코드이기 때문에 이렇게 구현하는 것이 바람직하다. 유사 문제: 1697번, 12851번 https://hseungyeon.tistory.com/222 [DFS/BFS/완전탐색] 1697번 - 숨바꼭질(BFS) [백준] 1697번 - 숨바꼭질 풀이 시간: 40분 이내 1) 문제 해결 아이디어 코드를 짜는데는 10분 정도 걸렸는데 오류를 고치는데 시간을 허비했다. 이 문제 같은 경우는 수빈이와 동생의 위치가 N, K로 hseungyeon.tistory.com https://hseungyeon.tistory.com/229 [DFS/BFS/완전탐색] ★ 12851번..

[Python]알고리즘/백준

[DFS/BFS/완전탐색] ★ 12851번 - 숨바꼭질 2(BFS)

[백준] 12851번 - 숨바꼭질 2 풀이 시간: 60분 이내 유사문제 1697번 https://hseungyeon.tistory.com/222 [DFS/BFS/완전탐색] 1697번 - 숨바꼭질(BFS) [백준] 1697번 - 숨바꼭질 풀이 시간: 40분 이내 1) 문제 해결 아이디어 코드를 짜는데는 10분 정도 걸렸는데 오류를 고치는데 시간을 허비했다. 이 문제 같은 경우는 수빈이와 동생의 위치가 N, K로 hseungyeon.tistory.com 1) 문제 해결 아이디어 알고리즘을 짜는 것 자체는 20분 정도 걸렸는데 오류를 고치는데 시간이 오래 걸린 문제로 계속 모르겠어서 검색을 통해 해결했다. 추후 복습이 꼭 필요한 문제!! 이 문제는 시작, 끝 위치가 주어졌을 때, 시작위치에서 끝위치까지 도달할..

HSY_mumu
'BFS' 태그의 글 목록 (2 Page)