PROGRAMMING
-
(라이님 블로그 대회 알고리즘 따라잡기 30) LCA(Lowest Common Ancestor)PROGRAMMING/알고리즘 2024. 7. 29. 11:58
오늘은 LCA를 배워보았다. 그 전에 Sparse Table에 대해 알아두면 좋을 것 같아 Sparse Table에 대해서도 공부해보았다. 라이님 LCA 포스팅을 보다보니 Sparse Table이 나왔는데 전에 본 적이 없어서 이 참에 공부! Sparse Table에 대한 설명은 블로그를 참고하고, 아래는 아주 조금 보기 쉽게 고친 코드이다.#include using namespace std;const int MAX = 500001;const int MAX_D = 19; // 2^k >= MAX인 최소의 kint main() { // next의 크기가 너무 클 경우 vector>로 정의 int M, next[MAX][MAX_D]; // 정점 입력 scanf("%d", &M); for..
-
(라이님 블로그 대회 알고리즘 따라잡기 28) 디닉 알고리즘(Dinic's Algorithm)PROGRAMMING/알고리즘 2024. 7. 23. 09:49
https://blog.naver.com/PostView.naver?blogId=kks227&logNo=220812858041&parentCategoryNo=&categoryNo=299&viewDate=&isShowPopularPosts=false&from=postList\ 디닉 알고리즘(Dinic's Algorithm) (수정: 2016-09-19)안녕하세요. 예고한 대로 더 빠른 시간복잡도의 최대 유량 알고리즘을 소개하러 왔습니다. 그런데, 본래는 ...blog.naver.com 시간복잡도 O(V^2E) 알고리즘인 이 알고리즘은 에드몬드 카프 알고리즘이 O(VE^2)이였던 알고리즘에 비해 빠른 알고리즘이다! 설명은 라이님 블로그를 참고할 것! 코드는 크게 BFS를 이용해 레벨 그래프를 구축하는 과정과..
-
(라이님 블로그 대회 알고리즘 따라잡기 26) 이분매칭(Bipartite Matching)PROGRAMMING/알고리즘 2024. 7. 22. 10:57
오늘은 네트워크 플로우의 특수한 케이스인 이분 매칭에 대해 배워보았다. 이론은 상당히 단순한데, 내용은 라이님 블로그에 자세히 설명되어 있다. https://blog.naver.com/PostView.naver?blogId=kks227&logNo=220807541506&parentCategoryNo=&categoryNo=299&viewDate=&isShowPopularPosts=false&from=postList 이분 매칭(Bipartite Matching)이번에 올릴 글은 네트워크 플로우 개념의 연장...은 아닌 것 같고, 유량 그래프의 아주 특수하면서 메이저...blog.naver.com 라이님이 알려준 코드를 살짝만 수정해서 사용하고자 한다.#include #include #include // m..
-
(라이님 블로그 대회 알고리즘 따라잡기 25) 네트워크 유량(Network Flow)PROGRAMMING/알고리즘 2024. 7. 16. 10:45
네트워크 유량에 대해 공부해보았다. 개념 자체는 어렵지 않은데 음의 유량 다루는 부분이 조금 생소했다. 아래 라이님 블로그에 아주 잘 기술되어 있으므로 정독하는 것을 추천!https://blog.naver.com/PostView.naver?blogId=kks227&logNo=220804885235&parentCategoryNo=&categoryNo=299&viewDate=&isShowPopularPosts=false&from=postList 네트워크 유량(Network Flow) (수정: 2019-08-14)안녕하세요. 그래프에 대해서 1차적으로 쓸 내용 중에서는 마지막 개념에 달했습니다. 그런데 마지막 개념...blog.naver.com ⭐ 플로우 그래프의 가장 큰 특징 : 간선의 용량!⭐ 어떤 길을..
-
(라이님 블로그 대회 알고리즘 따라잡기 24) 2-SAT(Satisfiability Problem)PROGRAMMING/알고리즘 2024. 7. 12. 11:36
라이님 블로그에서 이번에는 2-SAT(2-Satisfiability Problem)을 배워보았다.https://blog.naver.com/PostView.naver?blogId=kks227&logNo=220803009418&parentCategoryNo=&categoryNo=299&viewDate=&isShowPopularPosts=false&from=postList 2-SAT 문제(2-Satisfiability Problem) (수정: 2019-11-16)안녕하세요. 이번에 강의할 내용은 2-SAT(2-Satisfiability)이라는 좀 생소할 수 있는 내용입니다! 이...blog.naver.com 아직도 끝나지 않은 그래프 지옥...★ 코드는 저번 SCC 코드랑 비슷한 방식으로 작성해보았다.#inc..
-
Articulation point(단절점) 구하는 알고리즘PROGRAMMING/알고리즘 2024. 7. 8. 10:17
아래 블로그에서 정말 많은 도움을 받았으며, 자세한 설명은 아래 블로그에 모두 있습니다!!!!자세한 설명은 아래 글 참고https://ttl-blog.tistory.com/956 [알고리즘] 그래프 (3) - 연결 요소(Connected Components)와 단절점(Articulation Point)🧐 Connected Components 그래프 $G$ 의 Connected Component 인 $G'$ 은 다음과 같이 정의됩니다. Connected Component $G'$ of $G$ : Maximal connected subgraph of $G$ ✔️ Maximum과 Maximal의 차이 Maximum : 최대를 의미합니다. Maxittl-blog.tistory.com articulation p..
-
(백준 4196번 도미노) (라이님 블로그 대회 알고리즘 따라잡기 22) SCCPROGRAMMING/알고리즘 2024. 7. 4. 10:41
백준 4196번https://www.acmicpc.net/problem/4196 SCC를 푸는 것에 추가해서 SCC 하나를 하나의 노드로 보고 indegree가 0인 SCC의 갯수를 세는 문제! 라이님 블로그에서 풀이를 열심히 공부해서 내 식대로 바꿔보았다.https://blog.naver.com/PostView.naver?blogId=kks227&logNo=220802519976&parentCategoryNo=&categoryNo=299&viewDate=&isShowPopularPosts=false&from=postList 정말 많이 틀렸는데.. 대부분의 문제는 노드를 입력 그대로 받아서 생겼다..(보통 문제에서는 점이 1, 2, 3 ... 으로 주어지지만, 프로그래밍은 0, 1, 2...로 하니까....
-
(라이님 블로그 대회 알고리즘 따라잡기 22) 강한 연결 요소(Strongly Connected Component)PROGRAMMING/알고리즘 2024. 7. 2. 12:09
오늘은 라이님의 강한 연결 요소에 대해 알아보았다. 상세한 내용은 Reference를 참고하면 된다. 라이님이 알려준 알고리즘은 Robert Tarjan의 Tarjan 알고리즘이다.동빈나 선생님의 유튜브와 블로그 글도 매우 큰 도움이 된다!!(솔직히 이 유튜브 영상 없었으면 이해가 엄-청 오래 걸렸을 것 같다 ㅠㅡㅠ) 타잔 알고리즘) 동빈나님의 블로그에서 변수명을 내가 알아보기 쉽게 변경한 코드!#include #include #include #include #include // memesetusing namespace std;constexpr int MAX = 10000;int id = 0, disc[MAX]; // disc[i](discovery)는 노드 'i'가 DFS에 의해 처음 발견된 시기 의..