Submission #465673

#TimeUsernameProblemLanguageResultExecution timeMemory
465673AmirElarbiHandcrafted Gift (IOI20_gift)C++14
Compilation error
0 ms0 KiB
#include <bits/stdc++.h> #include "gift.h" #define vi vector<int> #define ve vector #define ll long long #define vf vector<float> #define vll vector<pair<ll,ll>> #define ii pair<int,int> #define vvi vector<vi> #define vii vector<ii> #define gii greater<ii> #define pb push_back #define fi first #define se second #define INF 1e10 #define unsigned u #define eps 1e-18 #define eps1 1e-25 #define optimise ios_base::sync_with_stdio(false);cin.tie(NULL); #define MAX_A 100005 #define V 450 #define re register #define maxi(a,b) ((a) > (b) ? (a) : (b)) ll MOD = 998244353; using namespace std; vi p; int findSet(int x){return (p[x] == x ? x : p[x] = findSet(p[x]));} bool isSameSet(int x, int y){return findSet(x) == findSet(y);} void unionSet(int x, int y){ int i = findSet(x), j = findSet(y); p[i] = j; } int construct(int n, int r, vector<int> a, vector<int> b, vector<int> x) { p.resize(n); set<int> st; string s; for(int i = 0 ; i < n; i++){ p[i] = i; st.insert(i); } for (int i = 0; i < r; ++i) { if(x[i] == 1){ auto lb = st.lower_bound(a[i]), ub = st2.lower_bound(b[i]); if(*ub != a[i]) ub--; for (int j = (*lb)+1; j <= *ub; ++j) { if(j != b[i]) st.erase(j); unionSet(j,j-1); } } } set<int> st2; for(int i = 0 ; i < n; i++){ st2.insert(i); } for (int i = 0; i < r; ++i) { bool p = false; if(x[i] == 2){ auto lb = st2.lower_bound(a[i]), ub = st2.lower_bound(b[i]); if(*ub != a[i]) ub--; for (int j = *lb+1; j <= *ub; ++j) { if(!isSameSet(j-1,j)){ p = true; } } if(!p) return 0; } } char p = 'R'; s += p; for (int i = 1; i < n; ++i) { if(isSameSet(i,i-1)){ s += p; } else { if(p == 'R') p = 'B'; else p = 'R'; s += p; } } craft(s); return 1; }

Compilation message (stderr)

gift.cpp: In function 'int construct(int, int, std::vector<int>, std::vector<int>, std::vector<int>)':
gift.cpp:45:50: error: 'st2' was not declared in this scope; did you mean 'st'?
   45 |             auto lb = st.lower_bound(a[i]), ub = st2.lower_bound(b[i]);
      |                                                  ^~~
      |                                                  st
gift.cpp:45:13: error: inconsistent deduction for 'auto': 'std::_Rb_tree_const_iterator<int>' and then '<type error>'
   45 |             auto lb = st.lower_bound(a[i]), ub = st2.lower_bound(b[i]);
      |             ^~~~