Submission #986631

# Submission time Handle Problem Language Result Execution time Memory
986631 2024-05-20T23:54:25 Z vjudge1 The Potion of Great Power (CEOI20_potion) C++17
17 / 100
3000 ms 154652 KB
#include<bits/stdc++.h>
using namespace std;
int SSZ=30;
vector<pair<int,int>>C[100100];
map<int,set<int>> temps[100100];
set<int>cur[100100];
int h[100100];
void init(int N, int D, int H[]) {
    for(int i=0;i<N;i++)
        h[i]=H[i],temps[i][-1];
}
void curseChanges(int U, int A[], int B[]) {
    for(int i=0;i<U;i++){
        if(cur[A[i]].count(B    [i]))
            cur[A[i]].erase(B[i]),
            cur[B[i]].erase(A[i]);
        else cur[A[i]].insert(B[i]),
            cur[B[i]].insert(A[i]);
        C[A[i]].push_back({i,B[i]});
        C[B[i]].push_back({i,A[i]});
        if(C[A[i]].size()%SSZ==0)
            temps[A[i]][i]=cur[A[i]];
        if(C[B[i]].size()%SSZ==0)
            temps[B[i]][i]=cur[B[i]];
    }
    for(auto&i:cur)
        i.clear();
}
int calc(vector<int>A,vector<int>B){
    int l=0,r=0,ans=1e9;
    while(l<A.size()&&r<B.size()){
        ans=min(ans,abs(A[l]-B[r]));
        if(A[l]<B[r])l++;
        else r++;
    }
    return ans;
}
int question(int x, int y, int v) {
    vector<int>A,B;
    auto it=--temps[x].lower_bound(v);
    set<int>X=it->second;
    auto it2=lower_bound(C[x].begin(),C[x].end(),make_pair(it->first+1,0));
    for(int i=it2-C[x].begin();i<C[x].size()&&C[x][i].first<v;i++)
        if(X.count(C[x][i].second))
            X.erase(C[x][i].second);
        else X.insert(C[x][i].second);
    for(auto i:X)A.push_back(h[i]);
    it=--temps[y].upper_bound(v);
    X=it->second;
    it2=lower_bound(C[y].begin(),C[y].end(),make_pair(it->first+1,0));
    for(int i=it2-C[y].begin();i<C[y].size()&&C[y][i].first<v;i++)
        if(X.count(C[y][i].second))
            X.erase(C[y][i].second);
        else X.insert(C[y][i].second);
    for(auto i:X)B.push_back(h[i]);
    sort(A.begin(),A.end());
    sort(B.begin(),B.end());
    return calc(A,B);
}

Compilation message

potion.cpp: In function 'int calc(std::vector<int>, std::vector<int>)':
potion.cpp:31:12: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   31 |     while(l<A.size()&&r<B.size()){
      |           ~^~~~~~~~~
potion.cpp:31:24: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   31 |     while(l<A.size()&&r<B.size()){
      |                       ~^~~~~~~~~
potion.cpp: In function 'int question(int, int, int)':
potion.cpp:43:33: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   43 |     for(int i=it2-C[x].begin();i<C[x].size()&&C[x][i].first<v;i++)
      |                                ~^~~~~~~~~~~~
potion.cpp:51:33: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<std::pair<int, int> >::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   51 |     for(int i=it2-C[y].begin();i<C[y].size()&&C[y][i].first<v;i++)
      |                                ~^~~~~~~~~~~~
# Verdict Execution time Memory Grader output
1 Correct 3 ms 12376 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 4 ms 12632 KB Output is correct
2 Correct 4 ms 12632 KB Output is correct
3 Correct 4 ms 12632 KB Output is correct
4 Correct 20 ms 22884 KB Output is correct
# Verdict Execution time Memory Grader output
1 Correct 310 ms 49240 KB Output is correct
2 Correct 303 ms 49204 KB Output is correct
3 Correct 273 ms 34472 KB Output is correct
4 Correct 1937 ms 107660 KB Output is correct
5 Correct 618 ms 53340 KB Output is correct
6 Execution timed out 3058 ms 147132 KB Time limit exceeded
7 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 281 ms 49332 KB Output is correct
2 Correct 2297 ms 154652 KB Output is correct
3 Correct 1328 ms 91128 KB Output is correct
4 Correct 2647 ms 146936 KB Output is correct
5 Correct 546 ms 55500 KB Output is correct
6 Execution timed out 3084 ms 146900 KB Time limit exceeded
7 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 40 ms 14684 KB Output is correct
2 Incorrect 138 ms 14168 KB Incorrect
3 Halted 0 ms 0 KB -
# Verdict Execution time Memory Grader output
1 Correct 3 ms 12376 KB Output is correct
2 Correct 4 ms 12632 KB Output is correct
3 Correct 4 ms 12632 KB Output is correct
4 Correct 4 ms 12632 KB Output is correct
5 Correct 20 ms 22884 KB Output is correct
6 Correct 310 ms 49240 KB Output is correct
7 Correct 303 ms 49204 KB Output is correct
8 Correct 273 ms 34472 KB Output is correct
9 Correct 1937 ms 107660 KB Output is correct
10 Correct 618 ms 53340 KB Output is correct
11 Execution timed out 3058 ms 147132 KB Time limit exceeded
12 Halted 0 ms 0 KB -