알고리즘

1. 그리디 알고리즘 (Greedy Algorithm, 탐욕법)이란? : 눈 앞의 이익만을 좇는 알고리즘. 매 선택마다 그 당시 가장 최적인 값을 선택한다. 2. 그리디 알고리즘 특징 1. 백트래킹으로 추가점검 X 백트래킹 : 해를 찾는 도중 해가 아니여서 막히면, 되돌아가서 다시 해를 찾아가는 기법 2. 최적해 ≠ 그리디 인 경우가 많다. 근데 안좋아보이는데 왜쓰냐? -> 정확하게 구하는 것보다 속도가 빠르다..! 따라서 정확한것 보단 근사값 구하는게 더 효율적일 때도 쓰임. (근사값 구하는 알고리즘에는 조합 탐색, 메타휴리스틱 알고리즘 등도 있음.) 3. 그리디 알고리즘을 사용해 최적해가 구해지기위한 조건 ( = 탐욕적 알고리즘의 정당성 증명) a. 탐욕 선택 속성(Greedy Choice Prope..
1. 우선순위 큐에 대해 일반적인 큐와 달리, 먼저 들어간 데이터가 아니라 우선순위가 높은 데이터가 먼저 나오는 자료구조 우선 순위를 적절이 조절함에 따라 일반적인 스택, 큐도 구현이 가능 힙을 통해 구현 가능 힙 : 부모 노드의 키 값이 항상 자식 노드의 키 값보다 큰 완전 이진 트리 배열, 연결리스트를 이용해 구현할 수도 있지만, 시간복잡도 면에서 힙을 통해 구현하는 방식이 효율적이다. 구현방식에 따른 시간 복잡도우선순위 큐 구현 방식 삽입시간 삭제시간 배열 $O(1)$ $O(N)$ 연결리스트 $O(N)$ or $O(1)$ $O(1)$ or $O(N)$ 힙 $O(logN)$ $O(logN)$ 2. 힙의 개념 Complete Binary Tree 루트노드부터 왼쪽 → 오른쪽 자식 노드 순서대로 데이터가..
문제 코드 #include #include #include using namespace std; int dp[1500100] = { 0, }; int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); int n; int section_max = 0; cin >> n; for (int i = 1; i > time >> pay; dp[i + time - 1] = max(section_max + pay, dp[i + time - 1]); if (dp[i] > section_max) section_max = dp[i]; } int max = *max_element(dp, dp + n + 1); cout
문제 코드 #include #include using namespace std; int dp[1001] = { 0, }; int arr[1001] = { 0, }; int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); fill(dp, dp + 1001, 1); int n = 0; cin >> n; for (int i = 0; i > arr[i]; } for (int i = 0; i < n; i++) { for (int j = 0; j dp[4](현재 2)기 때문에 dp[4]의 값이 3으로 갱신되며 dp[4]값이 정해지고, i값이 1 증가하면서 로직이 반복되며 dp 테이블이 채워진다. 위와 ..
문제 https://www.acmicpc.net/problem/11727 코드 #include #include using namespace std; int dp[1002] = { 0, }; int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); int n; cin >> n; dp[1] = 1; dp[2] = 3; for (int i = 3; i
문제 풀이 바킹독 알고리즘의 도움을 받아 푼 1753 최단경로를 풀고 바로 푼 문제. 매우 기본적인 다익스트라 알고리즘 !! 조금 추가적인 부분은 도착지를 제외한 모든 지점에서의 최단거리를 구해야하고, 도착지에서 출발지까지의 최단거리도 더해야한다는것. 실제로는 모든 정점에서 다른 정점까지의 최단 거리 테이블을 만들면 되는 문제였다. #include #include #include using namespace std; int INF = 0x7FFFFFFF; int d[1001][1001]; int main() { ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL); int n, m, x; int max_time = 0; vector graph[..
1. 다익스트라 알고리즘이란 하나의 시작 정점으로부터 다른 모든 정점까지의 최단 거리를 구하는 알고리즘으로, DP와 그리디로 분류된다. 하나의 최단 거리를 구할 때 그 이전까지 구했던 최단 거리 정보를 그대로 사용 (DP의 특징) 정점 = 노드 = V 간선 = E 음으로 표현되지 않는다. 2. 다익스트라 알고리즘 구현 작동과정 Characters: 1. vector graph// 그래프. graph[출발정점] = {가중치, 도착정점} 2. d[] // 최단거리 테이블 3. priority_queue pq; Operations 1. 출발 정점 설정 2. 출발 정점 기준, 다른 모든 정점까지의 최소 비용 테이블 저장 - 일반적으로 출발정점 → 출발정점 비용 : 0 & 출발 정점 → 다른 모든 정점까지의 최소..
조롱박박이
'알고리즘' 카테고리의 글 목록