Submission #676442

#TimeUsernameProblemLanguageResultExecution timeMemory
676442bogdanvladmihaiToll (BOI17_toll)C++14
10 / 100
246 ms84528 KiB
#include <bits/stdc++.h> using namespace std; const int INF = (int)1e9; int K, N, M, Q; vector<vector<vector<vector<int>>>> dp; int main() { cin >> K >> N >> M >> Q; dp.resize((N / K + 1) + 2, vector<vector<vector<int>>>(ceil(log2(N / K)) + 3, vector<vector<int>>(K, vector<int>(K, INF)))); for (int i = 0; i < M; i++) { int a, b, c; cin >> a >> b >> c; dp[a / K][0][a % K][b % K] = c; } for (int l = 1; (1 << (l - 1)) <= (N + K - 1) / K; l++) { for (int g = 0; g + (1 << l) < (N + K - 1) / K; g++) { for (int x = 0; x < K; x++) { for (int y = 0; y < K; y++) { for (int z = 0; z < K; z++) { dp[g][l][x][y] = min(dp[g][l][x][y], dp[g][l - 1][x][z] + dp[g + (1 << (l - 1))][l - 1][z][y]); } } } } } for (int i = 0; i < Q; i++) { int a, b; cin >> a >> b; vector<vector<int>> answer(K, vector<int>(K, INF)); for (int j = 0; j < K; j++) { answer[j][j] = 0; } int len = b / K - a / K, lst = a / K; for (int l = ceil(log2(len)) + 2; l >= 0; l--) { if ((len & (1 << l)) != 0) { vector<vector<int>> tmp(K, vector<int>(K, INF)); for (int x = 0; x < K; x++) { for (int y = 0; y < K; y++) { for (int z = 0; z < K; z++) { tmp[x][y] = min(tmp[x][y], answer[x][z] + dp[lst][l][z][y]); } } } answer = tmp; lst |= (1 << l); } } if (answer[a % K][b % K] == INF) { cout << "-1\n"; } else { cout << answer[a % K][b % K] << "\n"; } } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...