This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include "train.h"
#include <bits/stdc++.h>
using namespace std;
long long solve(int n, int m, int w, std::vector<int> T, std::vector<int> X, std::vector<int> Y,
std::vector<int> A, std::vector<int> B, std::vector<int> C, std::vector<int> L,
std::vector<int> R) {
vector<vector<int>> my(n);
for (int i = 0; i < m; i++) {
my[X[i]].push_back(A[i]);
my[Y[i]].push_back(B[i]);
}
my[0].push_back(-1);
vector<int> sz(n);
for (int i = 0; i < n; i++) {
sort(my[i].begin(), my[i].end());
if (!my[i].empty()) {
my[i].erase(unique(my[i].begin(), my[i].end()), my[i].end());
}
sz[i] = (int) my[i].size();
}
vector<pair<int, int>> vec;
for (int i = 0; i < n; i++) {
for (int j : my[i]) {
vec.emplace_back(i, j);
}
}
sort(vec.begin(), vec.end(), [&](pair<int, int> a, pair<int, int> b) {
return a.second < b.second;
});
const long long inf = (long long) 1e18;
vector<vector<long long>> dist(n);
for (int i = 0; i < n; i++) {
dist[i].resize(sz[i], inf);
}
dist[0][0] = 0;
auto Count = [&](int from, int to) {
int total = 0;
for (int i = 0; i < w; i++) {
if (from <= L[i] && R[i] <= to) {
total += 1;
}
}
return total;
};
vector<vector<vector<int>>> g(n);
for (int i = 0; i < n; i++) {
g[i].resize(sz[i]);
}
for (int i = 0; i < m; i++) {
int idx = (int) (lower_bound(my[X[i]].begin(), my[X[i]].end(), A[i]) - my[X[i]].begin());
g[X[i]][idx].push_back(i);
}
for (int qq = 0; qq < (int) vec.size(); qq++) {
int i = vec[qq].first;
int t = vec[qq].second;
int j = (int) (lower_bound(my[i].begin(), my[i].end(), t) - my[i].begin());
long long nd = dist[i][j];
for (int k = 0; k < j; k++) {
nd = min(nd, dist[i][k] + Count(my[i][k] + 1, my[i][j] - 1) * 1LL * T[i]);
}
for (auto& p : g[i][j]) {
int to = Y[p];
int time = B[p];
int idx = (int) (lower_bound(my[to].begin(), my[to].end(), time) - my[to].begin());
dist[to][idx] = min(dist[to][idx], nd + C[p]);
}
}
long long res = inf;
for (int i = 0; i < sz[n - 1]; i++) {
res = min(res, dist[n - 1][i] + Count(my[n - 1][i] + 1, 1000) * T[n - 1]);
}
if (res == inf) {
return -1;
} else {
return res;
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |