Submission #10682

#TimeUsernameProblemLanguageResultExecution timeMemory
10682dohyun0324즐거운 채소 기르기 (JOI14_growing)C++98
0 / 100
32 ms5776 KiB
#include<stdio.h> #include<algorithm> using namespace std; int dap,n,tree[600010]; struct data { int x,y; bool operator<(const data&r)const { return x<r.x; } }a[300010]; void update(int k,int x,int y,int p) { if(x>p || y<p) return; tree[k]++; if(x==y) return; update(k*2,x,(x+y)/2,p); update(k*2+1,(x+y)/2+1,y,p); } int query(int k,int x,int y,int p) { if(x>p) return 0; if(y>p) return query(k*2,x,(x+y)/2,p)+query(k*2+1,(x+y)/2+1,y,p); return tree[k]; } int main() { int i,s; scanf("%d",&n); for(i=1;i<=n;i++) { scanf("%d",&a[i].x); a[i].y=i; } sort(a+1,a+n+1); for(i=1;i<=n;i++) { s=query(1,1,n,a[i].y); dap+=min(a[i].y-s-1,(n-a[i].y)-(i-1-s)); update(1,1,n,a[i].y); } printf("%d",dap); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...