본문 바로가기

알고리즘/이론

(48)
Convex hull (볼록 껍질) [1. 개요]컨벡스 헐(이하 볼록 껍질) 이란?평면 위 N개의 점이 주어졌을 때,M 개의 점을 이용하여, 나머지 모든 점을 내부에 포함하게 만드는 도형.즉, 모든 점을 포함하는 볼록 다각형 중, 면적이 최소인 다각형을 말한다.[2. 알고리즘 - 개요]컨벡스 헐을 구하는 알고리즘은 아래와 같은 것들 있다.Graham scan (그라함 스캔)Jarvis marchDivide & Conquer여기서 가장 유명한 알고리즘이 그라함 스캔이라고 한다.그라함 스캔의 동작 방식은 아래와 같다.주어진 점을 y 순으로 정렬한다. (y 가 같은 경우는 x 순으로 정렬)정렬 된 점 중 첫번째 점을 기준으로 반시계 방향으로 나머지 점들을 정렬한다.정렬 된 점 들 중, 처음 2 개의 점을 스택에 푸쉬한다.그 다음 점이,  스택의..
네트워크 유량, Dinic 알고리즘 [1. 개요]네트워크의 최대 유량을 계산 할 때, 포드-풀커슨 알고리즘 외 디닉 알고리즘에 대한 정리https://testkernelv2.tistory.com/601[2. 알고리즘]디닉 알고리즘은 두가지 단계로 구성 된다.Level graph 의 생성Blocking flow 를 지키면서, 유량을 흘려보냄.더 이상 source 에서 sink 로 유량을 흘려 보낼 수 없을 때까지 위 과정을 반복한다.증가 경로 (Augmenting path) 가 없을 때 까지[3. Level graph]레벨 그래프는 BFS 를 이용하여 계산한다.Source 에서 시작하여, Sink 에 도달 할 때 까지 BFS 를 진행 하는 것이다. 여기서 Level 은 각 노드에 설정 되는데, Source 에서 해당 노드까지 도달한 최소 h..
이분매칭 [1. 개요] 이분 매칭을 설명하기에 앞서 이분 그래프에 대한 개념 정의 그래프의 모든 정점이 두 그룹으로 나누어 질 때 서로 다른 그룹의 정점들은 연결되지만 같은 그룹의 정점들은 서로 연결하지 않는 형태의 그래프 두 집합 간의 대응 관계를 표현하기 위해 사용 https://testkernelv2.tistory.com/338 매칭 그래프에서 끝점을 공유하지 않는 간선의 집합을 의미한다. 여기서 끝점을 공유하지 않는다는 의미는 아래와 같다. 두개 이상의 간선이 공유하는 정점이 있는 경우. 아래와 같은 형태의 그래프에서 어떤 조건을 만족하는 edge 만 선별하였다고 가정했을 때, 빨간색 간선이 선별된 edge 그래서 매칭 문제(최대 매칭 문제) 는 그래프에서 가장 큰 매칭을 찾는 문제를 말하며, 가장 큰 매..
네트워크 유량 - 예제1 [1. 문제 설명] https://algospot.com/judge/problem/read/MATCHFIX [2. 풀이 접근] [3. 코드]
네트워크 유량, 포드-풀커슨 [1. 개요] 그래프에서 간선에는 가중치라는 개념이 있다. 여기서 가중치 대신 용량이라는 개념을 적용하여, 일종의 파이프라고 모델링을 하고 이 간선을 통해 물을 흘려보낸다고 하자. 출발지에서 목적지까지 물을 흘려보낸다고 했을 때, 이 간선에 흐르는 양을 유량이라고 부를 수 있다. 이렇게, 각 간선이 용량을 갖는 그래프에서 두 정점 사이에 얼마나 많은 흐름 혹은 유량을 보낼 수 있는지 계산하는 문제를 네트워크 용량 문제라고 한다. [2. 유량 네트워크] 각 간선에 용량(Capacity) 라는 추가 속성이 존재하는 방향 그래프를 말한다. 이 간선을 통해 유량을 흘려 보낼 수 있다 정점 u 에서 정점 v 로 가는 간선에 대해서 아래와 같이 표기하도록 한다. 용량: c(u, v), capacity 유량: f(u..
bfs - 예제2 [1. 문제 설명] https://algospot.com/judge/problem/read/HANOI4 [3. 코드]
bfs - 예제1 [1. 문제 설명] https://algospot.com/judge/problem/read/CHILDRENDAY [2. 풀이 접근] 먼저 모든 어린이들에게 같은 수의 장난감을 주고, 욕심쟁이 어린이들에게는 원래 가진 것에서 하나 씩 더 주면 1차적인 조건을 만족 시킬 수 있다. 그래서 구하고자 하는 c 는 아래와 같은 조건이 성립한다. n + m 이상이다. c = kn + m 형태로, c 를 n 으로 나눈 나머지는 m 이다. d 에 포함된 숫자로만 구성되야 한다. 위와 같이 여러 조건을 동시에 만족하면서 답을 찾아야 할 때 일부 조건을 없앤 더 단순한 문제를 푼 후, 조건을 하나씩 추가해 가는 전략이 있다. 단, 어느 조건을 무시하고 문제를 푸느냐에 따라 난이도가 달라 질 수 있다. 여기서는 1번 조건을..
bfs [1. 개요] dfs 와 달리 시작점에서 가까운 정점부터 순서대로 방문하는 탐색 알고리즘 가중치가 없는 그래프에서, 어떤 시작 정점에서 다른 모든 정점까지의 최단 경로를 계산 할 수 있다. 탐색 중, 처음 방문하는 정점이 있다면 방문 예정이라고 체크하고, (발견 여부라고 보는 것이 좀 더 정확?) Queue 에 푸쉬한다. dfs 와 비교하여 bfs 에서 모든 정점은 3가지 상태를 갖는다. 아직 발견되지 않은 상태 발견되었지만, 아직 방문하지 않은 상태 => 정점의 큐에 저장 된 상태 방문된 상태 [2. bfs 와 최단 거리] bfs 는 보통 딱 하나의 용도로 사용되는데, 두 정점 간의 최단 경로 문제이다. 가중치가 없는 그래프에서 사용 가능 어떤 시작 상태에서 타겟으로 하는 상태까지 가장 빨리 도달하는데..
dfs - 절단점 [1. 개요] DFS 를 응용해서 해결 할 수 있는 문제 중 하나로, 어떤 무방향 그래프에서 절단점이란 이 점을 제거함으로 인해 edge 가 제거되고 이로 인해, 컴포넌트가 두개 이상으로 나뉘어지는 정점을 말한다. 최초 그래프가 하나의 컴포넌트로 이루어 졌는데, 어떤 정점을 제거하여, 그래프가 두개 이상의 컴포넌트로 나뉘어지면 전체 그래프는 연결되어 있지 않을 수 있다. 이러한 절단점을 찾기 위한 가장 단순한 방법은 아래와 같은데 모든 정점에 대해서, 정점을 제거하고 dfsAll() 을 수행해서 컴포넌트 개수의 변화가 있는지 확인한다. 탐색 과정에서 얻는 정보를 이용하면, 한번의 dfs 로 모든 절단점을 찾아 낼 수 있다. 참조) https://testkernelv2.tistory.com/441 [2. ..
dfs - 예제1 [1. 문제 설명] https://algospot.com/judge/problem/read/WORDCHAIN [2. 풀이 접근] [3. 코드]