답안 #1101944

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
1101944 2024-10-17T08:23:37 Z InvMOD Toll (BOI17_toll) C++14
7 / 100
43 ms 32732 KB
#include<bits/stdc++.h>

#define fi first
#define se second
#define pb push_back

using namespace std;

template<typename T> bool ckmx(T& a, const T& b){if(a < b) return a = b, true; return false;}
template<typename T> bool ckmn(T& a, const T& b){if(a > b) return a = b, true; return false;}

const int N = 5e5+5, Q = 1e6+5;
const int  K = 6, inf = 1e9+1;

struct Query{
    int a,b,id;
    Query(int a = 0, int b = 0, int id = 0): a(a), b(b), id(id) {}
};

int n, m, q, k;
int answer[N], d[6][N];
vector<pair<int,int>> adj[N], r_adj[N];

void Dnc(int l, int r, vector<Query>& Q){
    if(l == r){
        for(Query cur_q : Q){
            answer[cur_q.id] = 0;
        }
        return;
    }
    int m = l+r>>1;

    //cout << "DNC: " << l <<" " << r <<" " << m <<"\n";

    for(int i = l; i <= r; i++){
        for(int j = 0; j < k; j++){
            d[j][i] = inf;
            //cout << d[j][i] <<" ";
        }
        //cout <<"\n";
    }

    for(int i = max(l, m-k*2+1); i <= m; i++){
        for(pair<int,int> e : adj[i]){
            int v = e.fi, w = e.se;
            if(v > m){
                d[(i%k)][i] = 0;
                ckmn(d[(i%k)][v], w);
                //cout << "Avai: " << i <<" " << v <<"\n";
            }
        }
    }

    for(int i = m; i >= l; i--){
        for(pair<int,int> e : r_adj[i]){
            int v = e.fi, w = e.se;
            for(int j = 0; j < k; j++){
                ckmn(d[j][v], d[j][i] + w);
                //cout << "LM: " << d[j][v] <<" " << i <<" " << v <<" " << d[j][i] <<" " << w <<"\n";
            }
        }
    }

    for(int i = m+1; i <= r; i++){
        for(pair<int,int> e : adj[i]){
            int v = e.fi, w = e.se;
            for(int j = 0; j < k; j++){
                ckmn(d[j][v], d[j][i] + w);
            }
        }
    }

    vector<Query> Qleft, Qright;
    for(Query cur_q : Q){
        int l = cur_q.a, r = cur_q.b;
        if(l <= m && r > m){
            int res = inf;
            for(int i = 0; i < k; i++){
                ckmn(res, d[i][l] + d[i][r]);
            }
            ckmn(answer[cur_q.id], res);
        }
        else{
            if(r <= m){
                Qleft.pb(cur_q);
            }
            else Qright.pb(cur_q);
        }
    }

    Dnc(l, m, Qleft);
    Dnc(m+1, r, Qright);
    return;
}

void solve()
{
    cin >> k >> n >> m >> q;

    for(int i = 1; i <= m; i++){
        int a,b,t; cin >> a >> b >> t;
        adj[a].pb(make_pair(b, t));
        r_adj[b].pb(make_pair(a, t));
    }

    vector<Query> Q;
    for(int i = 1; i <= q; i++){
        int a,b; cin >> a >> b;
        Q.pb(Query(a, b, i));
        answer[i] = inf;
    }

    Dnc(0, n, Q);
    for(int i = 1; i <= q; i++){
        cout << (answer[i] == inf ? -1 : answer[i]) <<"\n";
    } cout <<"\n";
}

int32_t main(){
    ios_base::sync_with_stdio(0);
    cin.tie(0); cout.tie(0);

    #define name "InvMOD"
    if(fopen(name".INP", "r")){
        freopen(name".INP", "r", stdin);
        freopen(name".OUT", "w", stdout);
    }

    solve();
    return 0;
}

Compilation message

toll.cpp: In function 'void Dnc(int, int, std::vector<Query>&)':
toll.cpp:31:14: warning: suggest parentheses around '+' inside '>>' [-Wparentheses]
   31 |     int m = l+r>>1;
      |             ~^~
toll.cpp: In function 'int32_t main()':
toll.cpp:125:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
  125 |         freopen(name".INP", "r", stdin);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~
toll.cpp:126:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
  126 |         freopen(name".OUT", "w", stdout);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 32 ms 30724 KB Output is correct
2 Correct 6 ms 27216 KB Output is correct
3 Correct 5 ms 27216 KB Output is correct
4 Correct 6 ms 27216 KB Output is correct
5 Correct 8 ms 27216 KB Output is correct
6 Correct 6 ms 27216 KB Output is correct
7 Correct 7 ms 27216 KB Output is correct
8 Correct 25 ms 30732 KB Output is correct
9 Correct 31 ms 30528 KB Output is correct
10 Correct 9 ms 27764 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 43 ms 32732 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 5 ms 27216 KB Output is correct
2 Incorrect 5 ms 29264 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 5 ms 27216 KB Output is correct
2 Incorrect 5 ms 29264 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 32 ms 30724 KB Output is correct
2 Correct 6 ms 27216 KB Output is correct
3 Correct 5 ms 27216 KB Output is correct
4 Correct 6 ms 27216 KB Output is correct
5 Correct 8 ms 27216 KB Output is correct
6 Correct 6 ms 27216 KB Output is correct
7 Correct 7 ms 27216 KB Output is correct
8 Correct 25 ms 30732 KB Output is correct
9 Correct 31 ms 30528 KB Output is correct
10 Correct 9 ms 27764 KB Output is correct
11 Incorrect 43 ms 32732 KB Output isn't correct
12 Halted 0 ms 0 KB -