답안 #493879

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
493879 2021-12-13T09:30:43 Z KhoaHo Boat (APIO16_boat) C++11
9 / 100
51 ms 1360 KB
/// KoJa
#include <bits/stdc++.h>
using namespace std;
#define task "DUT03TEAMS"
#define pb push_back
#define SZ(a) (a).begin(), (a).end()
#define SZZ(a, Begin, End) (a) + (Begin), (a) + (Begin) + (End)
#define BIT(a) (1LL << (a))
#define vec vector
#define fi first
#define se second

typedef long long ll;
typedef pair<int, int> ii;

template <class T>
inline bool maximize(T &a, const T &b) { return (a < b ? (a = b) : 0); }
template <class T>
inline bool minimize(T &a, const T &b) { return (a > b ? (a = b) : 0); }
void init()
{
    freopen(task ".inp", "r", stdin);
    freopen(task ".out", "w", stdout);
}
void fastio()
{
    ios_base::sync_with_stdio(NULL);
    cin.tie(NULL);
    cout.tie(NULL);
}
const int N = 505;
const int mod = int(1e9) + 7;
void add(int &a, const int &b)
{
    a += b;
    if (a >= mod)
        a -= mod;
}
const ll INF = 1e18;
int n, mem1[N][N];
ii a[N];

int backtrack1(int i, int x)
{
    if (i == n + 1)
    {
        if (x != -1)
            return 1;
        return 0;
    }
    int &res = mem1[i][x];
    if (res != -1)
        return res;
    res = 0;
    add(res, backtrack1(i + 1, x));
    if (a[i].fi > x)
        add(res, backtrack1(i + 1, a[i].fi));
    return res;
}
int res = 0, dp[N][N], pref[N + 10], fact[N], ifact[N];
int Pow(int x, int y)
{
    int res = 1;
    while (y)
    {
        if (y & 1)
            res = 1LL * res * x % mod;

        x %= mod;
        x = 1LL * x * x % mod;
        y /= 2;
    }
    return res;
}
int main()
{
    fastio();
    //init();
    cin >> n;
    bool sub1 = (n <= 500);
    for (int i = 1; i <= n; i++)
    {
        cin >> a[i].fi >> a[i].se;
        sub1 &= (a[i].fi == a[i].se);
    }
    fact[0] = 1;
    for (int i = 1; i < N; i++)
        fact[i] = 1LL * fact[i - 1] * i % mod;
    ifact[N - 1] = Pow(fact[N - 1], mod - 2);
    for (int i = N - 1; i >= 1; i--)
        ifact[i - 1] = 1LL * ifact[i] * i % mod;
    vec<int> val;
    if (sub1)
    {
        for (int i = 1; i <= n; i++)
            val.pb(a[i].fi);
        sort(SZ(val));
        val.erase(unique(SZ(val)), val.end());
        for (int i = 1; i <= n; i++)
            a[i].fi = lower_bound(SZ(val), a[i].fi) - val.begin() + 1;
        memset(mem1, -1, sizeof(mem1));
        return cout << backtrack1(1, -1), 0;
    }
    for (int i = 1; i <= n; i++)
    {
        val.pb(a[i].fi);
        val.pb(a[i].se + 1);
    }
    sort(SZ(val));
    val.erase(unique(SZ(val)), val.end());
    for (int i = 1; i <= n; i++)
        a[i] = ii(lower_bound(SZ(val), a[i].fi) - val.begin() + 1, lower_bound(SZ(val), a[i].se) - val.begin() + 1);
    for (int i = 0; i <= val.size() + 5; i++)
        pref[i] = 1;
    dp[0][0] = 1;
    for (int i = 1; i <= n; i++)
    {
        for (int j = a[i].fi; j < a[i].se; j++)
        {
            int len = val[j + 1] - val[j];
            for (int k = N - 1; k >= 2; k--)
                add(dp[j][k], 1LL * dp[j][k - 1] * (len - k + 1) % mod * ifact[k] % mod);
            add(dp[j][1], 1LL * pref[j - 1] * len % mod);
        }
        pref[0] = dp[0][0];
        for (int j = 1; j < N; j++)
        {
            pref[j] = pref[j - 1];
            for (int k = 0; k < N; k++)
                add(pref[j], dp[j][k]);
        }
    }
    cout << (pref[N - 1] + mod - 1) % mod;
    return 0;
}

Compilation message

boat.cpp: In function 'int main()':
boat.cpp:113:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
  113 |     for (int i = 0; i <= val.size() + 5; i++)
      |                     ~~^~~~~~~~~~~~~~~~~
boat.cpp: In function 'void init()':
boat.cpp:22:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   22 |     freopen(task ".inp", "r", stdin);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~
boat.cpp:23:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   23 |     freopen(task ".out", "w", stdout);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 1356 KB Output is correct
2 Correct 3 ms 1356 KB Output is correct
3 Correct 3 ms 1356 KB Output is correct
4 Correct 2 ms 1356 KB Output is correct
5 Correct 2 ms 1356 KB Output is correct
6 Correct 2 ms 1356 KB Output is correct
7 Correct 2 ms 1360 KB Output is correct
8 Correct 3 ms 1356 KB Output is correct
9 Correct 2 ms 1356 KB Output is correct
10 Correct 3 ms 1356 KB Output is correct
11 Correct 3 ms 1356 KB Output is correct
12 Correct 2 ms 1360 KB Output is correct
13 Correct 3 ms 1356 KB Output is correct
14 Correct 3 ms 1356 KB Output is correct
15 Correct 3 ms 1356 KB Output is correct
16 Correct 2 ms 1356 KB Output is correct
17 Correct 2 ms 1356 KB Output is correct
18 Correct 1 ms 1356 KB Output is correct
19 Correct 1 ms 1356 KB Output is correct
20 Correct 1 ms 1356 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 1356 KB Output is correct
2 Correct 3 ms 1356 KB Output is correct
3 Correct 3 ms 1356 KB Output is correct
4 Correct 2 ms 1356 KB Output is correct
5 Correct 2 ms 1356 KB Output is correct
6 Correct 2 ms 1356 KB Output is correct
7 Correct 2 ms 1360 KB Output is correct
8 Correct 3 ms 1356 KB Output is correct
9 Correct 2 ms 1356 KB Output is correct
10 Correct 3 ms 1356 KB Output is correct
11 Correct 3 ms 1356 KB Output is correct
12 Correct 2 ms 1360 KB Output is correct
13 Correct 3 ms 1356 KB Output is correct
14 Correct 3 ms 1356 KB Output is correct
15 Correct 3 ms 1356 KB Output is correct
16 Correct 2 ms 1356 KB Output is correct
17 Correct 2 ms 1356 KB Output is correct
18 Correct 1 ms 1356 KB Output is correct
19 Correct 1 ms 1356 KB Output is correct
20 Correct 1 ms 1356 KB Output is correct
21 Runtime error 2 ms 844 KB Execution killed with signal 11
22 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Incorrect 51 ms 716 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 3 ms 1356 KB Output is correct
2 Correct 3 ms 1356 KB Output is correct
3 Correct 3 ms 1356 KB Output is correct
4 Correct 2 ms 1356 KB Output is correct
5 Correct 2 ms 1356 KB Output is correct
6 Correct 2 ms 1356 KB Output is correct
7 Correct 2 ms 1360 KB Output is correct
8 Correct 3 ms 1356 KB Output is correct
9 Correct 2 ms 1356 KB Output is correct
10 Correct 3 ms 1356 KB Output is correct
11 Correct 3 ms 1356 KB Output is correct
12 Correct 2 ms 1360 KB Output is correct
13 Correct 3 ms 1356 KB Output is correct
14 Correct 3 ms 1356 KB Output is correct
15 Correct 3 ms 1356 KB Output is correct
16 Correct 2 ms 1356 KB Output is correct
17 Correct 2 ms 1356 KB Output is correct
18 Correct 1 ms 1356 KB Output is correct
19 Correct 1 ms 1356 KB Output is correct
20 Correct 1 ms 1356 KB Output is correct
21 Runtime error 2 ms 844 KB Execution killed with signal 11
22 Halted 0 ms 0 KB -