#include #define rep(i,a,b) for (int i = a; i < b; i++) #define rrep(i,a,b) for (int i = a - 1; i >= b; i--) #define rng(a) a.begin(), a.end() #define rrng(a) a.rbegin(), a.rend() #define eb emplace_back #define pb push_back #define fi first #define se second #define pvec(a) for (int i = 0; i < a.size(); i++) cout << a[i] << " "; cout << '\n' #define dbwt(a) cout << fixed << setprecision(15) << a << '\n' using namespace std; using ll = long long; void wt() {cout << endl;} templatebool chmin(T& a, U b) {if (a > b) {a = b; return 1;} return 0;} templatebool chmax(T& a, U b) {if (a < b) {a = b; return 1;} return 0;} templatelong long llceil(T a, U b) {return (long long)(a + b - 1) / b;} templatevoid wt(H&& h, T&&... t){cout<(t)...);} //-------------------------------------------------------------------------------------// int main() { string S; cin >> S; int N = S.size(); bool kaibun = true; rep (i, 0, N / 2) { if (S[i] != S[N - i - 1]) kaibun = false; } bool allsame = *min_element(rng(S)) == *max_element(rng(S)); if (!kaibun) wt(N); else if (allsame) { if (N % 2 == 1) wt(-1); else wt(0); } else { wt(N - 2); } return 0; }