제출 #211154

#제출 시각아이디문제언어결과실행 시간메모리
211154arctanArranging Shoes (IOI19_shoes)C++14
50 / 100
1098 ms140712 KiB
#include<bits/stdc++.h> #include "shoes.h" using namespace std; #define pb push_back #define rep(i,n) for(ll i=0;i<n;i++) #define rep1(i,n) for(ll i=1;i<=n;i++) #define mp make_pair #define F first #define S second #define pf pop_front #define IOS ios_base::sync_with_stdio(0); cin.tie(0) typedef long long ll; const ll mod=1e9+7; const ll maxn=200005; const ll inf=1e9+7; queue<ll> m[2][100005]; ll bit[maxn]; inline ll lsb(int x) { return x&(-x); } void add(int x,int v) { int cnt=0; while(x<maxn) { bit[x]+=v; x+=lsb(x); cnt++; assert(cnt<=30); } } ll query(ll x) { assert(x>=0); ll res=0; int cnt=0; while(x) { res+=bit[x]; x-=lsb(x); cnt++; //assert(cnt<=10); } return res; } ll count_swaps(std::vector<int> s) { rep(i,s.size()) { bool x=0; if(s[i]<0) { x=1; m[x][-s[i]].push(i); } else m[x][s[i]].push(i); add(i+1,1); } ll sum=0; rep(i,s.size()) { bool x=(s[i]<0); s[i]=abs(s[i]); queue<ll> q=m[!x][s[i]]; if(q.empty()) continue; if(m[x][s[i]].front()!=i) continue; //assert(m[s[i]].size()==m[-s[i]].size()); ll p=q.front(); m[x][s[i]].pop(); m[!x][s[i]].pop(); sum+=query(p)-query(i+1); if(!x) sum++; //cout<<i<<" "<<sum<<"\n"; add(p+1,-1); add(i+1,-1); //if(i>50000) assert(0); } return sum; }

컴파일 시 표준 에러 (stderr) 메시지

shoes.cpp: In function 'll count_swaps(std::vector<int>)':
shoes.cpp:5:30: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
 #define rep(i,n) for(ll i=0;i<n;i++)
shoes.cpp:49:9:
     rep(i,s.size())
         ~~~~~~~~~~            
shoes.cpp:49:5: note: in expansion of macro 'rep'
     rep(i,s.size())
     ^~~
shoes.cpp:5:30: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
 #define rep(i,n) for(ll i=0;i<n;i++)
shoes.cpp:61:9:
     rep(i,s.size())
         ~~~~~~~~~~            
shoes.cpp:61:5: note: in expansion of macro 'rep'
     rep(i,s.size())
     ^~~
#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...
#Verdict Execution timeMemoryGrader output
Fetching results...