제출 #1024066

#제출 시각아이디문제언어결과실행 시간메모리
1024066serifefedartarTrains (BOI24_trains)C++17
100 / 100
196 ms9244 KiB
#include <bits/stdc++.h>
using namespace std;

#define fast ios::sync_with_stdio(0);cin.tie(0);
typedef long long ll;
#define f first
#define s second
#define LOGN 61
const ll MOD = 1e9 + 7;
const ll MAXN = 1e5 + 100;

#define int long long
const ll SQ = 400;
vector<int> omit[MAXN];
int classes[400][400], dp[MAXN], d[MAXN], x[MAXN];

signed main() {
    fast
    int N;
    cin >> N;

    dp[1] = 1;
    for (int i = 1; i <= N; i++) {
        for (auto u : omit[i])
            classes[d[u]][u % d[u]] = (classes[d[u]][u % d[u]] - dp[u] + MOD) % MOD;
        for (int m = 1; m < 400; m++)
            dp[i] = (dp[i] + classes[m][i % m]) % MOD;

        cin >> d[i] >> x[i];
        if (d[i] >= SQ) {
            for (int j = i + d[i]; j <= min(N, i + d[i] * x[i]); j += d[i])
                dp[j] = (dp[j] + dp[i]) % MOD;
        } else if (d[i] != 0) {
            classes[d[i]][i % d[i]] = (classes[d[i]][i % d[i]] + dp[i]) % MOD;
            omit[min(N+1, i + d[i] * x[i] + 1)].push_back(i);
        }
    }

    ll ans = 0;
    for (int i = 1; i <= N; i++)
        ans = (ans + dp[i]) % MOD;
    cout << ans << "\n";
}
#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...