Submission #1133944

#TimeUsernameProblemLanguageResultExecution timeMemory
1133944huoiTrains (BOI24_trains)C++17
37 / 100
243 ms212316 KiB
#include <bits/stdc++.h> using namespace std; #define int long long #define INF 1e9 #define M 1000000007 int add(int a, int b) { if (b < 0) b = (b + M) % M; return (a + b) % M; } void solve() { int n; cin >> n; vector<int> d(n + 1), x(n + 1); bool sub3 = true, sub4 = true; for (int i = 1; i <= n; i++) { cin >> d[i] >> x[i]; if (d[i] != 1) sub3 = false; if (x[i] != INF) sub4 = false; } if (sub3) { vector<int> dp(n + 1, 1); vector<int> dpp(n + 2); dpp[n] = 1; for (int i = n - 1; i >= 1; i--) { dp[i] = add(dp[i], add(dpp[i + 1], -dpp[min(i + x[i] + 1, n + 1)])); dpp[i] = add(dpp[i + 1], dp[i]); } cout << dp[1]; return; } if (sub4) { vector<int> dp(n + 1, 1); vector<int> dpp(n + 1); for (int i = n; i >= 1; i--) { for (int j = i + d[i]; j <= n; j += d[i]) { if (d[i] == d[j]) { // same jumps dp[i] = add(dp[i], dpp[j]); break; } dp[i] = add(dp[i], dp[j]); } dpp[i] = add(dpp[i + 1], dp[i]); } // for (int i = 1; i <= n; i++) cout << i << " \n"[i == n]; // for (int i = 1; i <= n; i++) cout << dp[i] << " \n"[i == n]; // for (int i = 1; i <= n; i++) cout << dpp[i] << " \n"[i == n]; cout << dp[1]; return; } vector<vector<int>> routes(n + 1); for (int i = 1; i <= n; i++) { for (int j = i + d[i]; j <= n; j += d[i]) { if (routes[i].size() == x[i] || d[i] == 0) break; routes[i].push_back(j); } } vector<int> dp(n + 1, 1); for (int i = n; i >= 1; i--) { for (int j : routes[i]) { dp[i] = add(dp[i], dp[j]) % M; } } cout << dp[1]; } signed main() { ios_base::sync_with_stdio(0); cin.tie(0); solve(); 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...