이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include<bits/stdc++.h>
using namespace std;
int noneg,k,b[100005],curindex,cursum,ans,n,a[100005];
queue<int>q[400005];
vector<int>s;
void update(int ind,int value) {
for(int i=ind; i<=n; i+=i&(-i))
b[i]+=value;
}
int curs(int ind1) {
cursum=0;
for(int i=ind1; i>=1; i-=i&(-i))
cursum+=b[i];
return cursum;
}
int count_swaps(std:: vector<int>s) {
noneg=100002; n=s.size();
for(k=0; k<s.size(); k++){
a[k+1]=s[k]; }
for(k=1;k<=n;k++)
update(k+1,1);
for(k=1; k<=n; k++) {
if(q[a[k]+noneg].size()>0) {
curindex=q[a[k]+noneg].front();
q[a[k]+noneg].pop();
ans+=curs(k)-curs(curindex)-1;
if(a[k]<0) ans++;
update(k,-1);
update(curindex,1);
} else q[a[k]*(-1)+noneg].push(k);
}
return ans;
}
컴파일 시 표준 에러 (stderr) 메시지
shoes.cpp: In function 'int count_swaps(std::vector<int>)':
shoes.cpp:20:12: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]
for(k=0; k<s.size(); k++){
~^~~~~~~~~| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |
| # | Verdict | Execution time | Memory | Grader output |
|---|
| Fetching results... |