본문 바로가기

백준24

[BOJ] 11000 강의실 배정 입력된 일정들을 겹치지 않게 구성하기 위해 필요한 강의실의 최솟값을 구하는 문제이다. 처음엔 queue로 풀고, 구성하지 못한 경우 뒤로 넘기는 방식을 선택했는데 이렇게 하니 worst case에서 시간복잡도가 O(n^2)가 되어 버린다. 생성된 방들의 일정 중 가장 나중에 끝나는 일정의 시간만 저장하고, 그것들을 비교하면 되는데, 방의 갯수가 늘어나게 될 때 모든 방을 불필요하게 비교하지 않아도 Priority queue로 구성하게 되면, 가장 일찍 끝나는 방의 경우만 살피면 되기 때문에 시간 복잡도를 n에서 logn으로 줄일 수 있게 된다. 고로 priority-queue엔 가장 늦게 끝나는 스케줄의 끝나는 시간만 넣어놓으면 된다. #include #include #include #include #i.. 2020. 4. 17.
[BOJ] 7579 앱 DP 문제인데, 정말 진땀 뺀 문제이다. 단순히 메모리의 크기를 index로 잡기엔 값이 너무 커서, cost를 인덱스로 잡아서 풀었다. 배열에 저장되는 값은 해당 cost로 얻을 수 있는 최대 Memory 이득이다. 포인트는 이부분이다. 순방향이 아니라 역방향으로 진행해야 메모리가 중복해서 사용되는 것을 방지할 수 있다. #include #include #include #include using namespace std; int N, M, temp; int c[101]; int m[101]; int dp[10001]; int main(){ scanf("%d %d", &N, &M); for(int i = 0 ; i < N ; i++){ scanf("%d", &m[i]); } for(int i = 0 ; .. 2020. 4. 16.
[BOJ] 11562 백양로 브레이크 이 문제는, 주어진 두 지점에 대해서 '최소 몇번 역방향 다리를 새로 놓아야 접근할 수 있는지' 에 대해 묻는 문제이다. 뒤집어서 생각하는 것이 관건이다. 길이 없는 경우 거리를 무한대, 양방향 길이 있는 경우 거리를 0, 단방향만 있는 경우는 길이 없는 방향에 대해 1 값을 부여한다. 그 후, Floyd-Warshall 알고리즘을 적용하면, 모든 Path에 대해 최단거리로 이동하기 위해 설치해야 할 다리의 갯수가 나온다. #include #include using namespace std; const int INF = 1 2020. 4. 14.
[BOJ] 2473 세 용액 3-SUM 알고리즘을 이용하여 문제를 풀 되, 정확한 조합이 아닌 가장 가까운 답을 찾는 것이 목표이다. 고로 합산한 결과 값 중 현재 최소인 조합의 결과를 저장해야 한다. #include #include #include #include using namespace std; int a, b, c; long long N, temp, best = LLONG_MAX; vector val; int main(){ cin >> N; for (int i = 0 ; i > temp; val.push_back(temp); } sort(val.begin(), val.end()); for(int first = 0 ; first < val.size() - 2; first++){ int secon.. 2020. 4. 11.