답안 #797265

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
797265 2023-07-29T08:39:17 Z vjudge1 푸드 코트 (JOI21_foodcourt) C++17
7 / 100
1000 ms 234528 KB

// Author : حسن

#include <bits/stdc++.h>



using namespace std;

#define TL ios::sync_with_stdio(0),cin.tie(0),cout.tie(0);
#define rall(s) s.rbegin(),s.rend()
#define all(s) s.begin(),s.end()
#define pb push_back
#define fi first
#define se second
#define ll long long
#define ld long double
#define YES cout<<"YES\n"
#define Yes cout<<"Yes\n"
#define yes cout<<"yes\n"
#define NO cout<<"NO\n"
#define No cout<<"No\n"
#define no cout<<"no\n"


const int N = 7e4 + 9 , mod = 1e9 + 7;
ll  a[N] = {},  c[N] , dp[N] = {} , b[N];
deque<ll>d[N];
vector<pair<ll,ll>>v[N];
struct qu{
    int k , l, r , x , y;
};
void solve(){
    ll q , i , j , m ,n, z , s  = 0, f, l , r , k , x , y , mn  = 1e18 , mx = -1;
    cin>>n>>m>>q;
    set<ll>st;
    if(n <= 2000 && q <= 2000){
    while(q--){
        cin>>k;
        if(k == 1){
            cin>>l>>r>>x>>y;
            for(i = l; i <=r ;i++){
                v[i].pb({y , x}) , b[i] += y;
                if(d[i].size() == 0)
                d[i].pb(y);
                else
                    d[i].pb(d[i].back() + y);
            }
        }else if(k == 2){
            cin>>l>>r>>x;
                for(i = l; i <= r; i++){
                    c[i] += x;
                    if(b[i]  < c[i])
                        c[i] = b[i];
                }
        }else{
            cin>>x>>y;
            if(b[x] - c[x] >= y){
                k = c[x] + y;
                l = 0;
                r = v[x].size() - 1;
                while(l != r){
                    m = (l + r) / 2;
                    if(d[x][m] >= k)
                        r = m ;
                    else
                        l = m + 1;
                }
                cout<<v[x][l].se<<"\n";
            }else {
            cout<<0<<"\n";
            }
        }
    }
    return;
    }
    vector<qu>vc;
    f = 0;
    while(q--){
        cin>>k;
        if(k == 1){
            cin>>l>>r>>x>>y;
            vc.pb({k , l , r , x, y });
            if(y != 1)
                f = 1;
        }else if(k == 2){
            cin>>l>>r>>x;
            if(x != 1)
                f = 1;
            vc.pb({k , l , r , x, y , });
        }else{
            cin>>x>>y;
            vc.pb({k , l , r , x, y , });
        }
    }
    z = 0;
    for(auto to : vc){
        cin>>k;
        k = to.k , l = to.l , r = to.r , x = to.x , y = to.x;
        if(f == 1){
        if(k == 1){
            for(i = l; i <=r ;i++)
                d[i].pb(x) , st.insert(i);
        }else if(k == 2){
            auto it = st.lower_bound(l);
            while(st.size() && it != st.end() && *it <= r){
            i = *it;
            s = 0;
            while(d[i].size() && s < x){
                d[i].pop_front();
                s++;
            }
            if(d[i].size() == 0)
                st.erase(i);
            it = st.lower_bound(i + 1);
            }
        }else{
            if(d[x].size() >= y)
                cout<<d[x][y - 1]<<"\n";
            else
                cout<<0<<"\n";
        }
        }else {
            if(k == 3){
                deque<int>v;
                for(i = 0; i < z; i++){
                    if(vc[i].k == 1 && vc[i].l <= x && vc[i].r >= x)
                        v.pb(vc[i].x);
                    if(vc[i].k == 2 && vc[i].l <= x && vc[i].r >= x)
                        v.pop_front();
                }
                if(v.size() >= y)
                    cout<<v[y - 1]<<"\n";
                else
                    cout<<0<<"\n";
            }
        }
        z++;
    }
}

int main(){

     TL;/*
     #ifndef ONLINE_JUDGE
     freopen("input.txt", "r", stdin);
     freopen("output.txt", "w", stdout);
     #endif
     */

int t = 1;
//cin>>t;

while(t--)
     {
     solve();
     }

}
// Author : حسن

Compilation message

foodcourt.cpp: In function 'void solve()':
foodcourt.cpp:84:20: warning: narrowing conversion of 'k' from 'long long int' to 'int' [-Wnarrowing]
   84 |             vc.pb({k , l , r , x, y });
      |                    ^
foodcourt.cpp:84:24: warning: narrowing conversion of 'l' from 'long long int' to 'int' [-Wnarrowing]
   84 |             vc.pb({k , l , r , x, y });
      |                        ^
foodcourt.cpp:84:28: warning: narrowing conversion of 'r' from 'long long int' to 'int' [-Wnarrowing]
   84 |             vc.pb({k , l , r , x, y });
      |                            ^
foodcourt.cpp:84:32: warning: narrowing conversion of 'x' from 'long long int' to 'int' [-Wnarrowing]
   84 |             vc.pb({k , l , r , x, y });
      |                                ^
foodcourt.cpp:84:35: warning: narrowing conversion of 'y' from 'long long int' to 'int' [-Wnarrowing]
   84 |             vc.pb({k , l , r , x, y });
      |                                   ^
foodcourt.cpp:91:20: warning: narrowing conversion of 'k' from 'long long int' to 'int' [-Wnarrowing]
   91 |             vc.pb({k , l , r , x, y , });
      |                    ^
foodcourt.cpp:91:24: warning: narrowing conversion of 'l' from 'long long int' to 'int' [-Wnarrowing]
   91 |             vc.pb({k , l , r , x, y , });
      |                        ^
foodcourt.cpp:91:28: warning: narrowing conversion of 'r' from 'long long int' to 'int' [-Wnarrowing]
   91 |             vc.pb({k , l , r , x, y , });
      |                            ^
foodcourt.cpp:91:32: warning: narrowing conversion of 'x' from 'long long int' to 'int' [-Wnarrowing]
   91 |             vc.pb({k , l , r , x, y , });
      |                                ^
foodcourt.cpp:91:35: warning: narrowing conversion of 'y' from 'long long int' to 'int' [-Wnarrowing]
   91 |             vc.pb({k , l , r , x, y , });
      |                                   ^
foodcourt.cpp:94:20: warning: narrowing conversion of 'k' from 'long long int' to 'int' [-Wnarrowing]
   94 |             vc.pb({k , l , r , x, y , });
      |                    ^
foodcourt.cpp:94:24: warning: narrowing conversion of 'l' from 'long long int' to 'int' [-Wnarrowing]
   94 |             vc.pb({k , l , r , x, y , });
      |                        ^
foodcourt.cpp:94:28: warning: narrowing conversion of 'r' from 'long long int' to 'int' [-Wnarrowing]
   94 |             vc.pb({k , l , r , x, y , });
      |                            ^
foodcourt.cpp:94:32: warning: narrowing conversion of 'x' from 'long long int' to 'int' [-Wnarrowing]
   94 |             vc.pb({k , l , r , x, y , });
      |                                ^
foodcourt.cpp:94:35: warning: narrowing conversion of 'y' from 'long long int' to 'int' [-Wnarrowing]
   94 |             vc.pb({k , l , r , x, y , });
      |                                   ^
foodcourt.cpp:119:28: warning: comparison of integer expressions of different signedness: 'std::deque<long long int>::size_type' {aka 'long unsigned int'} and 'long long int' [-Wsign-compare]
  119 |             if(d[x].size() >= y)
      |                ~~~~~~~~~~~~^~~~
foodcourt.cpp:133:29: warning: comparison of integer expressions of different signedness: 'std::deque<int>::size_type' {aka 'long unsigned int'} and 'long long int' [-Wsign-compare]
  133 |                 if(v.size() >= y)
      |                    ~~~~~~~~~^~~~
foodcourt.cpp:35:16: warning: unused variable 'j' [-Wunused-variable]
   35 |     ll q , i , j , m ,n, z , s  = 0, f, l , r , k , x , y , mn  = 1e18 , mx = -1;
      |                ^
foodcourt.cpp:35:61: warning: unused variable 'mn' [-Wunused-variable]
   35 |     ll q , i , j , m ,n, z , s  = 0, f, l , r , k , x , y , mn  = 1e18 , mx = -1;
      |                                                             ^~
foodcourt.cpp:35:74: warning: unused variable 'mx' [-Wunused-variable]
   35 |     ll q , i , j , m ,n, z , s  = 0, f, l , r , k , x , y , mn  = 1e18 , mx = -1;
      |                                                                          ^~
# 결과 실행 시간 메모리 Grader output
1 Correct 35 ms 56396 KB Output is correct
2 Correct 44 ms 63404 KB Output is correct
3 Correct 47 ms 67000 KB Output is correct
4 Correct 60 ms 79464 KB Output is correct
5 Correct 31 ms 49132 KB Output is correct
6 Correct 28 ms 49100 KB Output is correct
7 Correct 55 ms 71988 KB Output is correct
8 Correct 59 ms 71352 KB Output is correct
9 Correct 59 ms 71352 KB Output is correct
10 Correct 52 ms 72420 KB Output is correct
11 Correct 52 ms 73112 KB Output is correct
12 Correct 58 ms 72072 KB Output is correct
13 Correct 64 ms 82560 KB Output is correct
14 Correct 72 ms 90528 KB Output is correct
15 Correct 53 ms 71848 KB Output is correct
16 Correct 71 ms 90068 KB Output is correct
17 Correct 43 ms 60648 KB Output is correct
18 Correct 53 ms 67604 KB Output is correct
19 Correct 29 ms 49304 KB Output is correct
20 Correct 29 ms 49364 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 35 ms 56396 KB Output is correct
2 Correct 44 ms 63404 KB Output is correct
3 Correct 47 ms 67000 KB Output is correct
4 Correct 60 ms 79464 KB Output is correct
5 Correct 31 ms 49132 KB Output is correct
6 Correct 28 ms 49100 KB Output is correct
7 Correct 55 ms 71988 KB Output is correct
8 Correct 59 ms 71352 KB Output is correct
9 Correct 59 ms 71352 KB Output is correct
10 Correct 52 ms 72420 KB Output is correct
11 Correct 52 ms 73112 KB Output is correct
12 Correct 58 ms 72072 KB Output is correct
13 Correct 64 ms 82560 KB Output is correct
14 Correct 72 ms 90528 KB Output is correct
15 Correct 53 ms 71848 KB Output is correct
16 Correct 71 ms 90068 KB Output is correct
17 Correct 43 ms 60648 KB Output is correct
18 Correct 53 ms 67604 KB Output is correct
19 Correct 29 ms 49304 KB Output is correct
20 Correct 29 ms 49364 KB Output is correct
21 Correct 40 ms 62060 KB Output is correct
22 Correct 42 ms 63272 KB Output is correct
23 Correct 53 ms 68616 KB Output is correct
24 Correct 63 ms 79612 KB Output is correct
25 Correct 29 ms 49052 KB Output is correct
26 Correct 27 ms 49052 KB Output is correct
27 Correct 46 ms 68968 KB Output is correct
28 Correct 49 ms 72404 KB Output is correct
29 Correct 49 ms 72124 KB Output is correct
30 Correct 54 ms 71716 KB Output is correct
31 Correct 51 ms 68456 KB Output is correct
32 Correct 50 ms 68308 KB Output is correct
33 Correct 56 ms 81364 KB Output is correct
34 Correct 67 ms 90428 KB Output is correct
35 Correct 58 ms 78940 KB Output is correct
36 Correct 67 ms 89856 KB Output is correct
37 Correct 27 ms 49236 KB Output is correct
38 Correct 27 ms 49424 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Incorrect 64 ms 50516 KB Output isn't correct
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Runtime error 118 ms 108656 KB Execution killed with signal 11
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 35 ms 56396 KB Output is correct
2 Correct 44 ms 63404 KB Output is correct
3 Correct 47 ms 67000 KB Output is correct
4 Correct 60 ms 79464 KB Output is correct
5 Correct 31 ms 49132 KB Output is correct
6 Correct 28 ms 49100 KB Output is correct
7 Correct 55 ms 71988 KB Output is correct
8 Correct 59 ms 71352 KB Output is correct
9 Correct 59 ms 71352 KB Output is correct
10 Correct 52 ms 72420 KB Output is correct
11 Correct 52 ms 73112 KB Output is correct
12 Correct 58 ms 72072 KB Output is correct
13 Correct 64 ms 82560 KB Output is correct
14 Correct 72 ms 90528 KB Output is correct
15 Correct 53 ms 71848 KB Output is correct
16 Correct 71 ms 90068 KB Output is correct
17 Correct 43 ms 60648 KB Output is correct
18 Correct 53 ms 67604 KB Output is correct
19 Correct 29 ms 49304 KB Output is correct
20 Correct 29 ms 49364 KB Output is correct
21 Incorrect 64 ms 50516 KB Output isn't correct
22 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Execution timed out 1068 ms 234528 KB Time limit exceeded
2 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 35 ms 56396 KB Output is correct
2 Correct 44 ms 63404 KB Output is correct
3 Correct 47 ms 67000 KB Output is correct
4 Correct 60 ms 79464 KB Output is correct
5 Correct 31 ms 49132 KB Output is correct
6 Correct 28 ms 49100 KB Output is correct
7 Correct 55 ms 71988 KB Output is correct
8 Correct 59 ms 71352 KB Output is correct
9 Correct 59 ms 71352 KB Output is correct
10 Correct 52 ms 72420 KB Output is correct
11 Correct 52 ms 73112 KB Output is correct
12 Correct 58 ms 72072 KB Output is correct
13 Correct 64 ms 82560 KB Output is correct
14 Correct 72 ms 90528 KB Output is correct
15 Correct 53 ms 71848 KB Output is correct
16 Correct 71 ms 90068 KB Output is correct
17 Correct 43 ms 60648 KB Output is correct
18 Correct 53 ms 67604 KB Output is correct
19 Correct 29 ms 49304 KB Output is correct
20 Correct 29 ms 49364 KB Output is correct
21 Correct 40 ms 62060 KB Output is correct
22 Correct 42 ms 63272 KB Output is correct
23 Correct 53 ms 68616 KB Output is correct
24 Correct 63 ms 79612 KB Output is correct
25 Correct 29 ms 49052 KB Output is correct
26 Correct 27 ms 49052 KB Output is correct
27 Correct 46 ms 68968 KB Output is correct
28 Correct 49 ms 72404 KB Output is correct
29 Correct 49 ms 72124 KB Output is correct
30 Correct 54 ms 71716 KB Output is correct
31 Correct 51 ms 68456 KB Output is correct
32 Correct 50 ms 68308 KB Output is correct
33 Correct 56 ms 81364 KB Output is correct
34 Correct 67 ms 90428 KB Output is correct
35 Correct 58 ms 78940 KB Output is correct
36 Correct 67 ms 89856 KB Output is correct
37 Correct 27 ms 49236 KB Output is correct
38 Correct 27 ms 49424 KB Output is correct
39 Incorrect 64 ms 50516 KB Output isn't correct
40 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 35 ms 56396 KB Output is correct
2 Correct 44 ms 63404 KB Output is correct
3 Correct 47 ms 67000 KB Output is correct
4 Correct 60 ms 79464 KB Output is correct
5 Correct 31 ms 49132 KB Output is correct
6 Correct 28 ms 49100 KB Output is correct
7 Correct 55 ms 71988 KB Output is correct
8 Correct 59 ms 71352 KB Output is correct
9 Correct 59 ms 71352 KB Output is correct
10 Correct 52 ms 72420 KB Output is correct
11 Correct 52 ms 73112 KB Output is correct
12 Correct 58 ms 72072 KB Output is correct
13 Correct 64 ms 82560 KB Output is correct
14 Correct 72 ms 90528 KB Output is correct
15 Correct 53 ms 71848 KB Output is correct
16 Correct 71 ms 90068 KB Output is correct
17 Correct 43 ms 60648 KB Output is correct
18 Correct 53 ms 67604 KB Output is correct
19 Correct 29 ms 49304 KB Output is correct
20 Correct 29 ms 49364 KB Output is correct
21 Correct 40 ms 62060 KB Output is correct
22 Correct 42 ms 63272 KB Output is correct
23 Correct 53 ms 68616 KB Output is correct
24 Correct 63 ms 79612 KB Output is correct
25 Correct 29 ms 49052 KB Output is correct
26 Correct 27 ms 49052 KB Output is correct
27 Correct 46 ms 68968 KB Output is correct
28 Correct 49 ms 72404 KB Output is correct
29 Correct 49 ms 72124 KB Output is correct
30 Correct 54 ms 71716 KB Output is correct
31 Correct 51 ms 68456 KB Output is correct
32 Correct 50 ms 68308 KB Output is correct
33 Correct 56 ms 81364 KB Output is correct
34 Correct 67 ms 90428 KB Output is correct
35 Correct 58 ms 78940 KB Output is correct
36 Correct 67 ms 89856 KB Output is correct
37 Correct 27 ms 49236 KB Output is correct
38 Correct 27 ms 49424 KB Output is correct
39 Incorrect 64 ms 50516 KB Output isn't correct
40 Halted 0 ms 0 KB -