Notice
Recent Posts
Recent Comments
«   2024/12   »
1 2 3 4 5 6 7
8 9 10 11 12 13 14
15 16 17 18 19 20 21
22 23 24 25 26 27 28
29 30 31
Archives
Today
Total
관리 메뉴

블로그 언저리인 무언가

[백준/BOJ] 2056 작업 본문

Programming/BOJ

[백준/BOJ] 2056 작업

he1fire 2020. 9. 29. 15:45
728x90

문제 : 2056 작업

 

2056번: 작업

수행해야 할 작업 N개 (3 ≤ N ≤ 10000)가 있다. 각각의 작업마다 걸리는 시간(1 ≤ 시간 ≤ 100)이 정수로 주어진다. 몇몇 작업들 사이에는 선행 관계라는 게 있어서, 어떤 작업을 수행하기 위해 ��

www.acmicpc.net

각 작업의 수행 시간과 선행 작업을 할당받았을 때,

작업이 끝나는 최단시간을 출력하는 문제이다.

위상 정렬을 사용해 현재 작업할 수 있는 것부터 순차적으로 작업하면서

각 작업의 최소 시간을 구한 후 그중 최댓값을 찾으면 된다.


Code

#include <bits/stdc++.h>
#define ll long long
using namespace std;
ll N, M, T[10005], chk[10005], ans[10005];
vector<ll> arr[10005];
ll TopologySort(){
    ll ret=0;
    queue<ll> q;
    for (int i=1;i<=N;i++){
        if (chk[i]==0)
            q.push(i);
    }
    for (int i=1;i<=N;i++){
        ll x=q.front();
        q.pop();
        ans[x]+=T[x];
        for (int j=0;j<arr[x].size();j++){
            ll dx=arr[x][j];
            ans[dx]=max(ans[x],ans[dx]);
            if (--chk[dx]==0)
                q.push(dx);
        }
    }
    for (int i=1;i<=N;i++){
        ret=max(ans[i],ret);
    }
    return ret;
}
int main(){
    ios::sync_with_stdio(0);
    cin.tie(0);
    cin >> N;
    for (int i=1;i<=N;i++){
        cin >> T[i];
        cin >> M;
        for (int j=0;j<M;j++){
            ll a;
            cin >> a;
            arr[a].push_back(i);
            chk[i]++;
        }
    }
    cout << TopologySort();
    return 0;
}
728x90

'Programming > BOJ' 카테고리의 다른 글

[백준/BOJ] 1446 지름길  (0) 2020.09.30
[백준/BOJ] 1766 문제집  (0) 2020.09.29
[백준/BOJ] 1516 게임 개발  (0) 2020.09.29
[백준/BOJ] 17251 힘 겨루기  (0) 2020.09.29
[백준/BOJ] 2879 코딩은 예쁘게  (0) 2020.09.28
Comments