Submission #283843

#TimeUsernameProblemLanguageResultExecution timeMemory
283843AMO5Tenis (COI19_tenis)C++17
30 / 100
658 ms20472 KiB
//modified from koosaga'sol #include <bits/stdc++.h> using namespace std; #define fi first #define se second #define eb emplace_back #define mt make_tuple #define all(x) (x).begin(), (x).end() #define sz(x) int(x.size()) #define MOD 1000000007 typedef long long ll; typedef pair <int, int> ii; typedef pair <ll, ll> pll; typedef vector<int> vi; typedef vector<ll> vll; typedef long double ld; const ll INF=63; const int mxn=1e5+5; bool DEBUG=0; int n,q; int a[3][mxn]; map<int,int>pos[3]; int tree[mxn*4],lazy[mxn*4]; void puttag(int id, int v){ tree[id]+=v; lazy[id]+=v; return; } void pushdown(int id, int le, int ri){ ll x = lazy[id]; lazy[id]=0ll; if(le==ri||x==0)return; puttag(id*2,x); puttag(id*2+1,x); return; } void pushup(int id, int le, int ri){ tree[id]=min(tree[id*2],tree[id*2+1]); return; } void upd(int x, int y, int v, int id=1, int le=0, int ri=n-2){ if(x>ri||le>y)return; if(x<=le&&ri<=y){ puttag(id,v); return; } pushdown(id,le,ri); int mid=(le+ri)/2; upd(x,y,v,id*2,le,mid); upd(x,y,v,id*2+1,mid+1,ri); pushup(id,le,ri); } int query(int x, int y, int id=1, int le=0, int ri=n-2){ if(x>ri||le>y)return 1e9; if(x<=le&&ri<=y){ //cerr<<id<<" "<<le<<" "<<ri<<" : "<<tree[id]<<"\n"; return tree[id]; } pushdown(id,le,ri); int mid=(le+ri)/2; int left = query(x,y,id*2,le,mid); int right = query(x,y,id*2+1,mid+1,ri); return min(left,right); } void add(int x, int v){ int mn = min({pos[0][x],pos[1][x],pos[2][x]}); int mx = max({pos[0][x],pos[1][x],pos[2][x]}); //cerr<<x<<": "<<mn<<" "<<mx-1<<" "<<v<<"\n"; upd(mn,mx-1,v,1,0,n-2); } void run(int id=1, int le=0, int ri=n-2){ cerr<<id<<" "<<le<<" "<<ri<<" : "<<tree[id]<<"\n"; if(le==ri)return; int mid=(le+ri)/2; run(id*2,le,mid); run(id*2+1,mid+1,ri); return; } int main() { scanf("%d %d",&n,&q); for(int i=0; i<3; i++){ for(int j=1; j<=n; j++){ scanf("%d",&a[i][j]); a[i][j]--; pos[i][a[i][j]]=j; } } for(int i=0; i<n; i++){ add(i,+1); } //run(); while(q--){ int typ; scanf("%d",&typ); if(typ==1){ int x; scanf("%d",&x); x--; int mn = min({pos[0][x],pos[1][x],pos[2][x]}); //cerr<<"checking 0 "<<mn-1<<"\n"; //cerr<<query(1,mn-1,1,1,n-1)<<"\n"; puts(query(1,mn-1,1,0,n-2)?"DA":"NE"); }else{ int p,x,y; scanf("%d %d %d",&p,&x,&y); p--; x--; y--; add(x,-1); add(y,-1); swap(pos[p][x],pos[p][y]); add(x,+1); add(y,+1); } //run(); } } // READ & UNDERSTAND // ll, int overflow, array bounds, memset(0) // special cases (n=1?), n+1 (1-index) // do smth instead of nothing & stay organized // WRITE STUFF DOWN

Compilation message (stderr)

tenis.cpp: In function 'int main()':
tenis.cpp:95:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   95 |     scanf("%d %d",&n,&q);
      |     ~~~~~^~~~~~~~~~~~~~~
tenis.cpp:98:9: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
   98 |    scanf("%d",&a[i][j]);
      |    ~~~~~^~~~~~~~~~~~~~~
tenis.cpp:109:8: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  109 |   scanf("%d",&typ);
      |   ~~~~~^~~~~~~~~~~
tenis.cpp:112:9: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  112 |    scanf("%d",&x); x--;
      |    ~~~~~^~~~~~~~~
tenis.cpp:119:9: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
  119 |    scanf("%d %d %d",&p,&x,&y);
      |    ~~~~~^~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...