This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
# include <bits/stdc++.h>
# pragma GCC optimize("Ofast")
# define ll long long
# define fi first
# define se second
# define pb push_back
# define pf push_front
# define For(i, a, b) for( ll i = a; i < b; i++ )
# define in insert
# define all(a) a.begin(),a.end()
# define pi pair < ll, ll >
# define readfile(file) freopen ( (file + ".in").c_str(), "r", stdin)
# define writefile(file) freopen ( (file + ".out").c_str(), "w", stdout)
# define speed ios_base::sync_with_stdio(false);cin.tie(NULL)
# define SET(file) readfile(file);writefile(file);
# define LARGE 100005
using namespace std;
ll count_swaps( vector < int > S ) {
ll cnt = 0;
int n = S.size();
ll c = 0;
For ( i, 0, n ) {
if ( S[i] < 0 && S[i] != S[i + n - 1] && abs(S[i]) == abs(S[i + n - 1]) ) c++;
}
if ( c == n ) {
return ((n - 1) * n) / 2;
}
For ( i, 0, 2 * n ) {
if ( S[i] != S[i + 1] && abs(S[i]) == abs(S[i + 1]) && S[i] < 0 ) {
i++;
}
else {
For ( j, i + 1, 2 * n ) {
if ( S[i] != S[j] && abs(S[i]) == abs(S[j]) ) {
for ( int k = j; k > i + 1; k-- ) {
swap( S[k], S[k - 1] );
cnt++;
}
if ( S[i] > 0 ) {
swap( S[i], S[i + 1] );
cnt++;
}
break;
}
}
i++;
}
}
return cnt;
}
/*
int main() {
/// Author: _Dilshod_
speed;
vector < int > S = {-1, 1};
cout << count_swaps(S);
}
*/
# | 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... |