Submission #102253

# Submission time Handle Problem Language Result Execution time Memory
102253 2019-03-24T00:39:14 Z Benq Two Dishes (JOI19_dishes) C++14
74 / 100
4550 ms 131068 KB
#pragma GCC optimize ("O3")
#pragma GCC target ("sse4")

#include <bits/stdc++.h>
#include <ext/pb_ds/tree_policy.hpp>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/rope>

using namespace std;
using namespace __gnu_pbds;
using namespace __gnu_cxx;
 
typedef long long ll;
typedef long double ld;
typedef complex<ld> cd;

typedef pair<int, int> pi;
typedef pair<ll,ll> pl;
typedef pair<ld,ld> pd;

typedef vector<int> vi;
typedef vector<ld> vd;
typedef vector<ll> vl;
typedef vector<pi> vpi;
typedef vector<pl> vpl;
typedef vector<cd> vcd;

template <class T> using Tree = tree<T, null_type, less<T>, rb_tree_tag,tree_order_statistics_node_update>;

#define FOR(i, a, b) for (int i = (a); i < (b); i++)
#define F0R(i, a) for (int i = 0; i < (a); i++)
#define FORd(i,a,b) for (int i = (b)-1; i >= (a); i--)
#define F0Rd(i,a) for (int i = (a)-1; i >= 0; i--)
#define trav(a, x) for (auto& a : x)

#define mp make_pair
#define pb push_back
#define f first
#define s second
#define lb lower_bound
#define ub upper_bound

#define sz(x) (int)x.size()
#define beg(x) x.begin()
#define en(x) x.end()
#define all(x) beg(x), en(x)
#define resz resize

const int MOD = 1000000007; // 998244353
const ll INF = 1e18;
const int MX = 1<<20;
const ld PI = 4*atan((ld)1);

template<class T> void ckmin(T &a, T b) { a = min(a, b); }
template<class T> void ckmax(T &a, T b) { a = max(a, b); }

template<class A, class B> A operator+=(A& l, const B& r) { return l = l+r; }
template<class A, class B> A operator-=(A& l, const B& r) { return l = l-r; }
template<class A, class B> A operator*=(A& l, const B& r) { return l = l*r; }
template<class A, class B> A operator/=(A& l, const B& r) { return l = l/r; }

namespace input {
    template<class T> void re(complex<T>& x);
    template<class T1, class T2> void re(pair<T1,T2>& p);
    template<class T> void re(vector<T>& a);
    template<class T, size_t SZ> void re(array<T,SZ>& a);

    template<class T> void re(T& x) { cin >> x; }
    void re(double& x) { string t; re(t); x = stod(t); }
    void re(ld& x) { string t; re(t); x = stold(t); }
    template<class Arg, class... Args> void re(Arg& first, Args&... rest) { 
        re(first); re(rest...); 
    }

    template<class T> void re(complex<T>& x) { T a,b; re(a,b); x = cd(a,b); }
    template<class T1, class T2> void re(pair<T1,T2>& p) { re(p.f,p.s); }
    template<class T> void re(vector<T>& a) { F0R(i,sz(a)) re(a[i]); }
    template<class T, size_t SZ> void re(array<T,SZ>& a) { F0R(i,SZ) re(a[i]); }
}

using namespace input;

namespace output {
    template<class T1, class T2> void pr(const pair<T1,T2>& x);
    template<class T, size_t SZ> void pr(const array<T,SZ>& x);
    template<class T> void pr(const vector<T>& x);
    template<class T> void pr(const set<T>& x);
    template<class T1, class T2> void pr(const map<T1,T2>& x);

    template<class T> void pr(const T& x) { cout << x; }
    template<class Arg, class... Args> void pr(const Arg& first, const Args&... rest) { 
        pr(first); pr(rest...); 
    }

    template<class T1, class T2> void pr(const pair<T1,T2>& x) { 
        pr("{",x.f,", ",x.s,"}"); 
    }
    template<class T> void prContain(const T& x) {
        pr("{");
        bool fst = 1; trav(a,x) pr(!fst?", ":"",a), fst = 0; 
        pr("}");
    }
    template<class T, size_t SZ> void pr(const array<T,SZ>& x) { prContain(x); }
    template<class T> void pr(const vector<T>& x) { prContain(x); }
    template<class T> void pr(const set<T>& x) { prContain(x); }
    template<class T1, class T2> void pr(const map<T1,T2>& x) { prContain(x); }
    
    void ps() { pr("\n"); } 
    template<class Arg, class... Args> void ps(const Arg& first, const Args&... rest) { 
        pr(first," "); ps(rest...); // print w/ spaces
    }
}

using namespace output;

namespace io {
    void setIn(string s) { freopen(s.c_str(),"r",stdin); }
    void setOut(string s) { freopen(s.c_str(),"w",stdout); }
    void setIO(string s = "") {
        ios_base::sync_with_stdio(0); cin.tie(0); // fast I/O
        if (sz(s)) { setIn(s+".in"), setOut(s+".out"); } // for USACO
    }
}

using namespace io;

template<class T> T invGeneral(T a, T b) {
    a %= b; if (a == 0) return b == 1 ? 0 : -1;
    T x = invGeneral(b,a); 
    return x == -1 ? -1 : ((1-(ll)b*x)/a+b)%b;
}

template<class T> struct modInt {
    T val;
    T mod = 0;
    // static const T mod = MOD;

    void normalize() {
        if (mod == 0) return;
        val %= mod; if (val < 0) val += mod;
    }
    modInt(T v = 0, T m = 0) : val(v), mod(m) { normalize(); }
    // modInt(T v = 0, T m = 0) : val(v) { normalize(); }

    explicit operator T() const { return val; }
    friend ostream& operator<<(ostream& os, const modInt& a) { return os << a.val; }
    friend bool operator==(const modInt& a, const modInt& b) { return a.val == b.val; }
    friend bool operator!=(const modInt& a, const modInt& b) { return !(a == b); }

    friend void check(modInt& a, modInt& b) { // make sure all operations are valid
        // comment out if mod is static const
        if (a.mod > 0 && b.mod > 0) { assert(a.mod == b.mod); return; }
        T mod = max(a.mod,b.mod); if (mod == 0) mod = MOD;
        if (a.mod != mod) { a.mod = mod; a.normalize(); }
        if (b.mod != mod) { b.mod = mod; b.normalize(); }
    }
    friend modInt operator+(modInt a, modInt b) {
        check(a,b); a.val += (T)b;
        if (a.val >= a.mod) a.val -= a.mod;
        return a;
    }
    friend modInt operator-(modInt a, modInt b) {
        check(a,b); a.val -= (T)b; 
        if (a.val < 0) a.val += a.mod; 
        return a;
    }
    friend modInt operator-(const modInt& a) { return modInt(0)-a; }

    friend modInt operator*(modInt a, modInt b) {
        check(a,b); a.val = (ll)a.val*(T)b%a.mod; return a;
    }
    friend modInt exp(modInt a, ll p) {
        modInt ans(1,a.mod);
        for (; p; p /= 2, a *= a) if (p&1) ans *= a;
        return ans;
    }
    friend modInt inv(const modInt& a) {
        return {invGeneral(a.val,a.mod),a.mod};
        // return exp(b,b.mod-2) if prime
    }
    friend modInt operator/(modInt a, modInt b) { 
        check(a,b); return a*inv(b); 
    }
};

typedef modInt<int> mi;
typedef pair<mi,mi> pmi;
typedef vector<mi> vmi;
typedef vector<pmi> vpmi;

template<class T, int SZ> struct LazySegTree {
    T mx[2*SZ], lazy[2*SZ]; // set SZ to a power of 2
    
    LazySegTree() {
        F0R(i,2*SZ) {
            mx[i] = -INF;
            lazy[i] = 0;
        }
    }
    
    void push(int ind, int L, int R) {
        mx[ind] += lazy[ind];
        if (L != R) lazy[2*ind] += lazy[ind], lazy[2*ind+1] += lazy[ind];
        lazy[ind] = 0;
    }
    
    void pull(int ind) {
        mx[ind] = max(mx[2*ind],mx[2*ind+1]);
    }
    
    void build() {
        FORd(i,1,SZ) pull(i);
    }

    T qmax(int lo, int hi, int ind = 1, int L = 0, int R = SZ-1) {
        push(ind,L,R);
        if (lo > R || L > hi) return -INF;
        if (lo <= L && R <= hi) return mx[ind];
        
        int M = (L+R)/2;
        return max(qmax(lo,hi,2*ind,L,M), qmax(lo,hi,2*ind+1,M+1,R));
    }
    
    void upd(int lo, int hi, ll inc, int ind = 1, int L = 0, int R = SZ-1) {
        push(ind,L,R);
        if (hi < L || R < lo) return;
        if (lo <= L && R <= hi) {
            lazy[ind] = inc;
            push(ind,L,R);
            return;
        }
        
        int M = (L+R)/2;
        upd(lo,hi,inc,2*ind,L,M); upd(lo,hi,inc,2*ind+1,M+1,R);
        pull(ind);
    }
    
    void tri(int pos, ll val, int ind = 1, int L = 0, int R = SZ-1) {
        push(ind,L,R);
        if (pos < L || R < pos) return;
        if (pos <= L && R <= pos) {
            ckmax(mx[ind],val);
            return;
        }
        
        int M = (L+R)/2;
        tri(pos,val,2*ind,L,M); tri(pos,val,2*ind+1,M+1,R);
        pull(ind);
    }
};

LazySegTree<ll,MX> L;
int N,M;
ll A[MX], S[MX], P[MX], B[MX], T[MX], Q[MX];
ll ans;
vector<array<ll,3>> points;

int main() {
    setIO(); re(N,M);
    FOR(i,1,N+1) {
        re(A[i],S[i],P[i]);
        A[i] += A[i-1];
    }
    FOR(i,1,M+1) {
        re(B[i],T[i],Q[i]);
        B[i] += B[i-1];
    }
    FOR(i,1,N+1) {
        int ind = ub(B,B+M+1,S[i]-A[i])-B-1;
        points.pb({i,ind,P[i]});
    }
    FOR(i,1,M+1) {
        int ind = ub(A,A+N+1,T[i]-B[i])-A-1;
        // ind,i
        ans += Q[i];
        points.pb({ind+1,i-1,-Q[i]});
    }
    L.tri(0,0);
    sort(all(points),[](const auto& a, const auto& b) {
        if (a[0] != b[0]) return a[0] < b[0];
        return a[1] > b[1];
    });
    // ps(points);
    for (int i = 0; i < sz(points); ) {
        auto t = points[i]; i ++;
        while (i < sz(points) && mp(points[i][0],points[i][1]) == mp(points[i-1][0],points[i-1][1])) {
            t[2] += points[i][2];
            i ++;
        }
        if (t[0] == 0) {
            L.upd(0,0,t[2]);
            continue;
        }
        if (t[1] < 0) continue;
        L.tri(t[1]+1,L.qmax(0,t[1]));
        L.upd(0,t[1],t[2]);
    }
    ps(ans+L.qmax(0,M));
}

/* stuff you should look for
    * int overflow, array bounds
    * special cases (n=1?), set tle
    * do smth instead of nothing and stay organized
*/

Compilation message

dishes.cpp: In function 'void io::setIn(std::__cxx11::string)':
dishes.cpp:117:35: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result]
     void setIn(string s) { freopen(s.c_str(),"r",stdin); }
                            ~~~~~~~^~~~~~~~~~~~~~~~~~~~~
dishes.cpp: In function 'void io::setOut(std::__cxx11::string)':
dishes.cpp:118:36: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)', declared with attribute warn_unused_result [-Wunused-result]
     void setOut(string s) { freopen(s.c_str(),"w",stdout); }
                             ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 541 ms 63488 KB Output is correct
2 Correct 635 ms 62560 KB Output is correct
3 Correct 583 ms 62788 KB Output is correct
4 Correct 538 ms 62660 KB Output is correct
5 Correct 28 ms 33144 KB Output is correct
6 Correct 511 ms 62432 KB Output is correct
7 Correct 279 ms 51048 KB Output is correct
8 Correct 389 ms 51176 KB Output is correct
9 Correct 566 ms 62792 KB Output is correct
10 Correct 369 ms 62432 KB Output is correct
11 Correct 604 ms 62828 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 28 ms 33272 KB Output is correct
2 Correct 27 ms 33152 KB Output is correct
3 Correct 30 ms 33276 KB Output is correct
4 Correct 28 ms 33152 KB Output is correct
5 Correct 28 ms 33272 KB Output is correct
6 Correct 29 ms 33272 KB Output is correct
7 Correct 31 ms 33272 KB Output is correct
8 Correct 30 ms 33244 KB Output is correct
9 Correct 28 ms 33272 KB Output is correct
10 Correct 27 ms 33280 KB Output is correct
11 Correct 30 ms 33272 KB Output is correct
12 Correct 29 ms 33280 KB Output is correct
13 Correct 28 ms 33144 KB Output is correct
14 Correct 29 ms 33232 KB Output is correct
15 Correct 29 ms 33144 KB Output is correct
16 Correct 29 ms 33144 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 28 ms 33272 KB Output is correct
2 Correct 27 ms 33152 KB Output is correct
3 Correct 30 ms 33276 KB Output is correct
4 Correct 28 ms 33152 KB Output is correct
5 Correct 28 ms 33272 KB Output is correct
6 Correct 29 ms 33272 KB Output is correct
7 Correct 31 ms 33272 KB Output is correct
8 Correct 30 ms 33244 KB Output is correct
9 Correct 28 ms 33272 KB Output is correct
10 Correct 27 ms 33280 KB Output is correct
11 Correct 30 ms 33272 KB Output is correct
12 Correct 29 ms 33280 KB Output is correct
13 Correct 28 ms 33144 KB Output is correct
14 Correct 29 ms 33232 KB Output is correct
15 Correct 29 ms 33144 KB Output is correct
16 Correct 29 ms 33144 KB Output is correct
17 Correct 35 ms 33632 KB Output is correct
18 Correct 38 ms 33528 KB Output is correct
19 Correct 37 ms 33660 KB Output is correct
20 Correct 32 ms 33612 KB Output is correct
21 Correct 35 ms 33528 KB Output is correct
22 Correct 33 ms 33528 KB Output is correct
23 Correct 32 ms 33480 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 28 ms 33272 KB Output is correct
2 Correct 27 ms 33152 KB Output is correct
3 Correct 30 ms 33276 KB Output is correct
4 Correct 28 ms 33152 KB Output is correct
5 Correct 28 ms 33272 KB Output is correct
6 Correct 29 ms 33272 KB Output is correct
7 Correct 31 ms 33272 KB Output is correct
8 Correct 30 ms 33244 KB Output is correct
9 Correct 28 ms 33272 KB Output is correct
10 Correct 27 ms 33280 KB Output is correct
11 Correct 30 ms 33272 KB Output is correct
12 Correct 29 ms 33280 KB Output is correct
13 Correct 28 ms 33144 KB Output is correct
14 Correct 29 ms 33232 KB Output is correct
15 Correct 29 ms 33144 KB Output is correct
16 Correct 29 ms 33144 KB Output is correct
17 Correct 35 ms 33632 KB Output is correct
18 Correct 38 ms 33528 KB Output is correct
19 Correct 37 ms 33660 KB Output is correct
20 Correct 32 ms 33612 KB Output is correct
21 Correct 35 ms 33528 KB Output is correct
22 Correct 33 ms 33528 KB Output is correct
23 Correct 32 ms 33480 KB Output is correct
24 Correct 617 ms 63424 KB Output is correct
25 Correct 524 ms 63024 KB Output is correct
26 Correct 568 ms 62968 KB Output is correct
27 Correct 514 ms 62952 KB Output is correct
28 Correct 609 ms 62988 KB Output is correct
29 Correct 540 ms 62928 KB Output is correct
30 Correct 730 ms 62936 KB Output is correct
31 Correct 312 ms 49484 KB Output is correct
32 Correct 384 ms 49512 KB Output is correct
33 Correct 625 ms 62940 KB Output is correct
34 Correct 724 ms 62940 KB Output is correct
35 Correct 757 ms 59320 KB Output is correct
36 Correct 712 ms 59428 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 28 ms 33272 KB Output is correct
2 Correct 27 ms 33152 KB Output is correct
3 Correct 30 ms 33276 KB Output is correct
4 Correct 28 ms 33152 KB Output is correct
5 Correct 28 ms 33272 KB Output is correct
6 Correct 29 ms 33272 KB Output is correct
7 Correct 31 ms 33272 KB Output is correct
8 Correct 30 ms 33244 KB Output is correct
9 Correct 28 ms 33272 KB Output is correct
10 Correct 27 ms 33280 KB Output is correct
11 Correct 30 ms 33272 KB Output is correct
12 Correct 29 ms 33280 KB Output is correct
13 Correct 28 ms 33144 KB Output is correct
14 Correct 29 ms 33232 KB Output is correct
15 Correct 29 ms 33144 KB Output is correct
16 Correct 29 ms 33144 KB Output is correct
17 Correct 35 ms 33632 KB Output is correct
18 Correct 38 ms 33528 KB Output is correct
19 Correct 37 ms 33660 KB Output is correct
20 Correct 32 ms 33612 KB Output is correct
21 Correct 35 ms 33528 KB Output is correct
22 Correct 33 ms 33528 KB Output is correct
23 Correct 32 ms 33480 KB Output is correct
24 Correct 617 ms 63424 KB Output is correct
25 Correct 524 ms 63024 KB Output is correct
26 Correct 568 ms 62968 KB Output is correct
27 Correct 514 ms 62952 KB Output is correct
28 Correct 609 ms 62988 KB Output is correct
29 Correct 540 ms 62928 KB Output is correct
30 Correct 730 ms 62936 KB Output is correct
31 Correct 312 ms 49484 KB Output is correct
32 Correct 384 ms 49512 KB Output is correct
33 Correct 625 ms 62940 KB Output is correct
34 Correct 724 ms 62940 KB Output is correct
35 Correct 757 ms 59320 KB Output is correct
36 Correct 712 ms 59428 KB Output is correct
37 Correct 558 ms 62808 KB Output is correct
38 Correct 598 ms 62788 KB Output is correct
39 Correct 492 ms 62988 KB Output is correct
40 Correct 494 ms 62920 KB Output is correct
41 Correct 29 ms 33152 KB Output is correct
42 Correct 806 ms 62908 KB Output is correct
43 Correct 620 ms 62780 KB Output is correct
44 Correct 773 ms 62884 KB Output is correct
45 Correct 748 ms 62424 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 28 ms 33272 KB Output is correct
2 Correct 27 ms 33152 KB Output is correct
3 Correct 30 ms 33276 KB Output is correct
4 Correct 28 ms 33152 KB Output is correct
5 Correct 28 ms 33272 KB Output is correct
6 Correct 29 ms 33272 KB Output is correct
7 Correct 31 ms 33272 KB Output is correct
8 Correct 30 ms 33244 KB Output is correct
9 Correct 28 ms 33272 KB Output is correct
10 Correct 27 ms 33280 KB Output is correct
11 Correct 30 ms 33272 KB Output is correct
12 Correct 29 ms 33280 KB Output is correct
13 Correct 28 ms 33144 KB Output is correct
14 Correct 29 ms 33232 KB Output is correct
15 Correct 29 ms 33144 KB Output is correct
16 Correct 29 ms 33144 KB Output is correct
17 Correct 35 ms 33632 KB Output is correct
18 Correct 38 ms 33528 KB Output is correct
19 Correct 37 ms 33660 KB Output is correct
20 Correct 32 ms 33612 KB Output is correct
21 Correct 35 ms 33528 KB Output is correct
22 Correct 33 ms 33528 KB Output is correct
23 Correct 32 ms 33480 KB Output is correct
24 Correct 617 ms 63424 KB Output is correct
25 Correct 524 ms 63024 KB Output is correct
26 Correct 568 ms 62968 KB Output is correct
27 Correct 514 ms 62952 KB Output is correct
28 Correct 609 ms 62988 KB Output is correct
29 Correct 540 ms 62928 KB Output is correct
30 Correct 730 ms 62936 KB Output is correct
31 Correct 312 ms 49484 KB Output is correct
32 Correct 384 ms 49512 KB Output is correct
33 Correct 625 ms 62940 KB Output is correct
34 Correct 724 ms 62940 KB Output is correct
35 Correct 757 ms 59320 KB Output is correct
36 Correct 712 ms 59428 KB Output is correct
37 Correct 558 ms 62808 KB Output is correct
38 Correct 598 ms 62788 KB Output is correct
39 Correct 492 ms 62988 KB Output is correct
40 Correct 494 ms 62920 KB Output is correct
41 Correct 29 ms 33152 KB Output is correct
42 Correct 806 ms 62908 KB Output is correct
43 Correct 620 ms 62780 KB Output is correct
44 Correct 773 ms 62884 KB Output is correct
45 Correct 748 ms 62424 KB Output is correct
46 Correct 3031 ms 131068 KB Output is correct
47 Correct 2793 ms 130768 KB Output is correct
48 Correct 2262 ms 130348 KB Output is correct
49 Correct 2252 ms 130140 KB Output is correct
50 Correct 4536 ms 130596 KB Output is correct
51 Correct 3624 ms 129080 KB Output is correct
52 Correct 4204 ms 127668 KB Output is correct
53 Correct 4550 ms 129980 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 541 ms 63488 KB Output is correct
2 Correct 635 ms 62560 KB Output is correct
3 Correct 583 ms 62788 KB Output is correct
4 Correct 538 ms 62660 KB Output is correct
5 Correct 28 ms 33144 KB Output is correct
6 Correct 511 ms 62432 KB Output is correct
7 Correct 279 ms 51048 KB Output is correct
8 Correct 389 ms 51176 KB Output is correct
9 Correct 566 ms 62792 KB Output is correct
10 Correct 369 ms 62432 KB Output is correct
11 Correct 604 ms 62828 KB Output is correct
12 Correct 28 ms 33272 KB Output is correct
13 Correct 27 ms 33152 KB Output is correct
14 Correct 30 ms 33276 KB Output is correct
15 Correct 28 ms 33152 KB Output is correct
16 Correct 28 ms 33272 KB Output is correct
17 Correct 29 ms 33272 KB Output is correct
18 Correct 31 ms 33272 KB Output is correct
19 Correct 30 ms 33244 KB Output is correct
20 Correct 28 ms 33272 KB Output is correct
21 Correct 27 ms 33280 KB Output is correct
22 Correct 30 ms 33272 KB Output is correct
23 Correct 29 ms 33280 KB Output is correct
24 Correct 28 ms 33144 KB Output is correct
25 Correct 29 ms 33232 KB Output is correct
26 Correct 29 ms 33144 KB Output is correct
27 Correct 29 ms 33144 KB Output is correct
28 Correct 35 ms 33632 KB Output is correct
29 Correct 38 ms 33528 KB Output is correct
30 Correct 37 ms 33660 KB Output is correct
31 Correct 32 ms 33612 KB Output is correct
32 Correct 35 ms 33528 KB Output is correct
33 Correct 33 ms 33528 KB Output is correct
34 Correct 32 ms 33480 KB Output is correct
35 Correct 617 ms 63424 KB Output is correct
36 Correct 524 ms 63024 KB Output is correct
37 Correct 568 ms 62968 KB Output is correct
38 Correct 514 ms 62952 KB Output is correct
39 Correct 609 ms 62988 KB Output is correct
40 Correct 540 ms 62928 KB Output is correct
41 Correct 730 ms 62936 KB Output is correct
42 Correct 312 ms 49484 KB Output is correct
43 Correct 384 ms 49512 KB Output is correct
44 Correct 625 ms 62940 KB Output is correct
45 Correct 724 ms 62940 KB Output is correct
46 Correct 757 ms 59320 KB Output is correct
47 Correct 712 ms 59428 KB Output is correct
48 Correct 558 ms 62808 KB Output is correct
49 Correct 598 ms 62788 KB Output is correct
50 Correct 492 ms 62988 KB Output is correct
51 Correct 494 ms 62920 KB Output is correct
52 Correct 29 ms 33152 KB Output is correct
53 Correct 806 ms 62908 KB Output is correct
54 Correct 620 ms 62780 KB Output is correct
55 Correct 773 ms 62884 KB Output is correct
56 Correct 748 ms 62424 KB Output is correct
57 Incorrect 621 ms 62400 KB Output isn't correct
58 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 541 ms 63488 KB Output is correct
2 Correct 635 ms 62560 KB Output is correct
3 Correct 583 ms 62788 KB Output is correct
4 Correct 538 ms 62660 KB Output is correct
5 Correct 28 ms 33144 KB Output is correct
6 Correct 511 ms 62432 KB Output is correct
7 Correct 279 ms 51048 KB Output is correct
8 Correct 389 ms 51176 KB Output is correct
9 Correct 566 ms 62792 KB Output is correct
10 Correct 369 ms 62432 KB Output is correct
11 Correct 604 ms 62828 KB Output is correct
12 Correct 28 ms 33272 KB Output is correct
13 Correct 27 ms 33152 KB Output is correct
14 Correct 30 ms 33276 KB Output is correct
15 Correct 28 ms 33152 KB Output is correct
16 Correct 28 ms 33272 KB Output is correct
17 Correct 29 ms 33272 KB Output is correct
18 Correct 31 ms 33272 KB Output is correct
19 Correct 30 ms 33244 KB Output is correct
20 Correct 28 ms 33272 KB Output is correct
21 Correct 27 ms 33280 KB Output is correct
22 Correct 30 ms 33272 KB Output is correct
23 Correct 29 ms 33280 KB Output is correct
24 Correct 28 ms 33144 KB Output is correct
25 Correct 29 ms 33232 KB Output is correct
26 Correct 29 ms 33144 KB Output is correct
27 Correct 29 ms 33144 KB Output is correct
28 Correct 35 ms 33632 KB Output is correct
29 Correct 38 ms 33528 KB Output is correct
30 Correct 37 ms 33660 KB Output is correct
31 Correct 32 ms 33612 KB Output is correct
32 Correct 35 ms 33528 KB Output is correct
33 Correct 33 ms 33528 KB Output is correct
34 Correct 32 ms 33480 KB Output is correct
35 Correct 617 ms 63424 KB Output is correct
36 Correct 524 ms 63024 KB Output is correct
37 Correct 568 ms 62968 KB Output is correct
38 Correct 514 ms 62952 KB Output is correct
39 Correct 609 ms 62988 KB Output is correct
40 Correct 540 ms 62928 KB Output is correct
41 Correct 730 ms 62936 KB Output is correct
42 Correct 312 ms 49484 KB Output is correct
43 Correct 384 ms 49512 KB Output is correct
44 Correct 625 ms 62940 KB Output is correct
45 Correct 724 ms 62940 KB Output is correct
46 Correct 757 ms 59320 KB Output is correct
47 Correct 712 ms 59428 KB Output is correct
48 Correct 558 ms 62808 KB Output is correct
49 Correct 598 ms 62788 KB Output is correct
50 Correct 492 ms 62988 KB Output is correct
51 Correct 494 ms 62920 KB Output is correct
52 Correct 29 ms 33152 KB Output is correct
53 Correct 806 ms 62908 KB Output is correct
54 Correct 620 ms 62780 KB Output is correct
55 Correct 773 ms 62884 KB Output is correct
56 Correct 748 ms 62424 KB Output is correct
57 Correct 3031 ms 131068 KB Output is correct
58 Correct 2793 ms 130768 KB Output is correct
59 Correct 2262 ms 130348 KB Output is correct
60 Correct 2252 ms 130140 KB Output is correct
61 Correct 4536 ms 130596 KB Output is correct
62 Correct 3624 ms 129080 KB Output is correct
63 Correct 4204 ms 127668 KB Output is correct
64 Correct 4550 ms 129980 KB Output is correct
65 Incorrect 621 ms 62400 KB Output isn't correct
66 Halted 0 ms 0 KB -