#include<iostream>
using namespace std;
int main(){
std::ios_base::sync_with_stdio(false);
std::cin.tie(NULL);
string tekst;
cin >> tekst;
int dl = tekst.length();
// cout << dl;
int a = 0, b = 0;
if(dl%2 == 0){
for(int i = 0; i < dl; i++){
if(tekst[i] == 'a'){
a++;
}
else{
b++;
}
}
// cout << a << b;
if(a%2 == 1 and b%2 == 1){
cout << "-1";
return 0;
}
}
int zmiany = 0;
for(int i = 0; i < dl/2; i++){
if( tekst[i] != tekst[dl-i-1]){
int j1 = i + 1, j2 = dl - i - 2;
char litera1 = tekst[i], litera2 = tekst[dl-i-1];
while(litera1 != litera2){
if(tekst[j1] != litera1){
zmiany += j1 - i;
tekst[i] = tekst[j1];
tekst[j1] = litera1;
litera1 = '0';
litera2 = '0';
}
else{
if(tekst[j2] != litera2){
zmiany += j1 - i;
tekst[dl-i-1] = tekst[j2];
tekst[j2] = litera2;
litera2 = '0';
litera1 = '0';
}
else{
j1++;
j2--;
}
}
}
}
}
cout << zmiany;
//cout << "alpha";
return 0;
}
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 | #include<iostream> using namespace std; int main(){ std::ios_base::sync_with_stdio(false); std::cin.tie(NULL); string tekst; cin >> tekst; int dl = tekst.length(); // cout << dl; int a = 0, b = 0; if(dl%2 == 0){ for(int i = 0; i < dl; i++){ if(tekst[i] == 'a'){ a++; } else{ b++; } } // cout << a << b; if(a%2 == 1 and b%2 == 1){ cout << "-1"; return 0; } } int zmiany = 0; for(int i = 0; i < dl/2; i++){ if( tekst[i] != tekst[dl-i-1]){ int j1 = i + 1, j2 = dl - i - 2; char litera1 = tekst[i], litera2 = tekst[dl-i-1]; while(litera1 != litera2){ if(tekst[j1] != litera1){ zmiany += j1 - i; tekst[i] = tekst[j1]; tekst[j1] = litera1; litera1 = '0'; litera2 = '0'; } else{ if(tekst[j2] != litera2){ zmiany += j1 - i; tekst[dl-i-1] = tekst[j2]; tekst[j2] = litera2; litera2 = '0'; litera1 = '0'; } else{ j1++; j2--; } } } } } cout << zmiany; //cout << "alpha"; return 0; } |
English