본문 바로가기

전체 글65

[백준][파이썬]2178번: 미로탐색 2178번: 미로 탐색 첫째 줄에 두 정수 N, M(2 ≤ N, M ≤ 100)이 주어진다. 다음 N개의 줄에는 M개의 정수로 미로가 주어진다. 각각의 수들은 붙어서 입력으로 주어진다. www.acmicpc.net 문제 출처 : https://www.acmicpc.net/problem/2178 내 풀이 (틀렸습니다) from collections import deque n, m = map(int, input().split()) map_ = [] for i in range(n): map_.append(list(map(int, input()))) def bfs(x, y): dx = [-1, 1, 0, 0] dy = [0, 0, -1, 1] queue = deque() queue.append((x, y)) w.. 2021. 12. 30.
[백준][파이썬]4963번: 섬의 개수 문제 출처 : https://www.acmicpc.net/problem/4963 4963번: 섬의 개수 입력은 여러 개의 테스트 케이스로 이루어져 있다. 각 테스트 케이스의 첫째 줄에는 지도의 너비 w와 높이 h가 주어진다. w와 h는 50보다 작거나 같은 양의 정수이다. 둘째 줄부터 h개 줄에는 지도 www.acmicpc.net 내 풀이 from collections import deque def check(a, b): map1[a][b] queue = deque() queue.append([a, b]) while queue: a, b = queue.popleft() for i in range(8): x = a + move[i][0] y = b + move[i][1] if 0 2021. 7. 4.
크루스칼 알고리즘(Kruskal Algorithm) 크루스칼 알고리즘 그리디 알고리즘의 하나로 최소 신장 트리 알고리즘을 해결할 때 쓰이는 대표적인 알고리즘이다. 구체적인 알고리즘 1. 간선 데이터를 비용에 따라 오름차순으로 정렬한다. 2. 간선을 하나씩 확인하며 현재의 간선이 사이클을 발생시키는지 확인한다. i. 사이클이 발생하지 않는 경우 최소 신장 트리에 포함시킨다. ii. 사이클이 발생하는 경우 최소 신장트리에 포함시키지 않는다. 3. 모든 간선에 대하여 2번의 과정을 반복한다. + 최소 신장 트리는 일종의 트리 자료구조이므로, 최종적으로 신장 트리에 포함되는 간선의 개수가 '노드의 개수 - 1'과 같다는 특징이 있다. + 가중치를 오름차순으로 정렬 후 가장 짧은 노선부터 연결해 나가는 것이 특징이다. + union-find를 이용해 사이클의 발생.. 2021. 6. 1.
[백준][파이썬]2805번: 나무 자르기 문제 출처 : https://www.acmicpc.net/problem/2805 2805번: 나무 자르기 첫째 줄에 나무의 수 N과 상근이가 집으로 가져가려고 하는 나무의 길이 M이 주어진다. (1 ≤ N ≤ 1,000,000, 1 ≤ M ≤ 2,000,000,000) 둘째 줄에는 나무의 높이가 주어진다. 나무의 높이의 합은 항상 M보 www.acmicpc.net 내 풀이 import sys input = sys.stdin.readline n, m = map(int, input().split()) high = list(map(int, input().split())) start = 0 end = max(high) while start 0 else 0 for i in high) if cnt < m: end .. 2021. 6. 1.