BFS 5

[TIL] 250717 - 프로그래머스 아이템 줍기

문제 설명다음과 같은 다각형 모양 지형에서 캐릭터가 아이템을 줍기 위해 이동하려 합니다.지형은 각 변이 x축, y축과 평행한 직사각형이 겹쳐진 형태로 표현하며, 캐릭터는 이 다각형의 둘레(굵은 선)를 따라서 이동합니다.만약 직사각형을 겹친 후 다음과 같이 중앙에 빈 공간이 생기는 경우, 다각형의 가장 바깥쪽 테두리가 캐릭터의 이동 경로가 됩니다.단, 서로 다른 두 직사각형의 x축 좌표 또는 y축 좌표가 같은 경우는 없습니다.즉, 위 그림처럼 서로 다른 두 직사각형이 꼭짓점에서 만나거나, 변이 겹치는 경우 등은 없습니다.다음 그림과 같이 지형이 2개 이상으로 분리된 경우도 없습니다.한 직사각형이 다른 직사각형 안에 완전히 포함되는 경우 또한 없습니다.지형을 나타내는 직사각형이 담긴 2차원 배열 rectan..

공부기록/TIL 2025.07.17

[TIL] 250716 - 프로그래머스 전력망을 둘로 나누기

문제 설명n개의 송전탑이 전선을 통해 하나의 트리 형태로 연결되어 있습니다. 당신은 이 전선들 중 하나를 끊어서 현재의 전력망 네트워크를 2개로 분할하려고 합니다. 이때, 두 전력망이 갖게 되는 송전탑의 개수를 최대한 비슷하게 맞추고자 합니다.송전탑의 개수 n, 그리고 전선 정보 wires가 매개변수로 주어집니다. 전선들 중 하나를 끊어서 송전탑 개수가 가능한 비슷하도록 두 전력망으로 나누었을 때, 두 전력망이 가지고 있는 송전탑 개수의 차이(절대값)를 return 하도록 solution 함수를 완성해주세요. 제한사항n은 2 이상 100 이하인 자연수입니다.wires는 길이가 n-1인 정수형 2차원 배열입니다. 입출력 예nwiresresult9[[1,3],[2,3],[3,4],[4,5],[4,6],[4,..

공부기록/TIL 2025.07.16

[TIL] 250713 - 프로그래머스 단어 변환

문제 설명두 개의 단어 begin, target과 단어의 집합 words가 있습니다. 아래와 같은 규칙을 이용하여 begin에서 target으로 변환하는 가장 짧은 변환 과정을 찾으려고 합니다.1. 한 번에 한 개의 알파벳만 바꿀 수 있습니다.2. words에 있는 단어로만 변환할 수 있습니다. 예를 들어 begin이 "hit", target가 "cog", words가 ["hot","dot","dog","lot","log","cog"]라면 "hit" -> "hot" -> "dot" -> "dog" -> "cog"와 같이 4단계를 거쳐 변환할 수 있습니다.두 개의 단어 begin, target과 단어의 집합 words가 매개변수로 주어질 때, 최소 몇 단계의 과정을 거쳐 begin을 target으로 변환할..

공부기록/TIL 2025.07.13

[TIL] 250713 - BFS (Breadth-First Search) 정리

출처: 바킹독 실전 알고리즘 강의1. BFS란?그래프 또는 2차원 배열에서 가장 가까운 노드부터 차례로 탐색하는 알고리즘탐색 방향: 너비 우선 탐색 (횡적)DFS와는 다르게 레벨 순서대로 탐색최단 거리 보장이 필요한 문제에 자주 사용됨2. BFS 특징 요약자료구조Queue (deque 사용)탐색 순서가까운 노드 → 먼 노드시간복잡도O(V + E) / 2차원에서는 O(N × M)구현 팁dx, dy를 이용한 방향 탐색, vis로 방문 체크대표 활용최단거리, 영역 탐색, 거리 측정, 전파 시뮬레이션 등3. 기본 동작 흐름시작점을 큐에 넣고 방문 처리큐가 빌 때까지 다음을 반복큐에서 원소를 꺼냄현재 위치에서 네 방향 탐색유효한 이웃이라면 큐에 추가 + 방문 처리4. 기본 코드 틀 (Python)from coll..

공부기록/TIL 2025.07.13

[TIL] 250530 - 프로그래머스 네트워크

문제 설명네트워크란 컴퓨터 상호 간에 정보를 교환할 수 있도록 연결된 형태를 의미합니다. 예를 들어, 컴퓨터 A와 컴퓨터 B가 직접적으로 연결되어있고, 컴퓨터 B와 컴퓨터 C가 직접적으로 연결되어 있을 때 컴퓨터 A와 컴퓨터 C도 간접적으로 연결되어 정보를 교환할 수 있습니다. 따라서 컴퓨터 A, B, C는 모두 같은 네트워크 상에 있다고 할 수 있습니다.컴퓨터의 개수 n, 연결에 대한 정보가 담긴 2차원 배열 computers가 매개변수로 주어질 때, 네트워크의 개수를 return 하도록 solution 함수를 작성하시오.제한사항컴퓨터의 개수 n은 1 이상 200 이하인 자연수입니다.각 컴퓨터는 0부터 n-1인 정수로 표현합니다.i번 컴퓨터와 j번 컴퓨터가 연결되어 있으면 computers[i][j]를..

공부기록/TIL 2025.05.30