#include #define rep(i,n) for (int i = 0; i < (n); i ++) using namespace std; typedef long long ll; typedef pair P; typedef pair PL; const ll MOD = 1e9 + 7; const ll INF = 1e10; const vector dy = {-1,0,1,0}; const vector dx = {0,1,0,-1}; int sub() { int n; string s; cin >> n >> s; if (n <= 2) { cout << 'X' << endl; return 0; } rep(i,n - 2) { if (s[i] == 'o' && s[i + 1] == 'o' && s[i + 2] == 'o') { cout << 'O' << endl; return 0; } if (s[i] == 'o' && s[i + 1] == '-' && s[i + 2] == 'o') { cout << 'O' << endl; return 0; } } rep(i,n - 1) { if (s[i] == 'o' && s[i + 1] == 'o') { if (i == 0) { if (s[i + 2] == 'x') continue; else {cout << 'O' << endl; return 0;; } } if (i == n - 2 ) { if (s[i - 1] == 'x') continue; else {cout << 'O' << endl; return 0;} } if (s[i - 1] == 'x' && s[i + 2] == 'x') continue; else {cout << 'O' << endl; return 0;} } } int cnt_ = 0; int cnto = 0; int idxo; rep(i,n) { if (s[i] == 'x') { if (cnt_ + cnto == 4) { if (cnto == 1 && ((idxo + 2 == i) || (idxo + 3 == i))) { cout << 'O' << endl;; return 0; } } if (cnt_ + cnto >= 5) { if (idxo + 1 == i || idxo + cnt_ + cnto == i) { continue; } else { cout << 'O' << endl; return 0; } } cnto = 0; cnt_ = 0; } if (s[i] == 'o') { idxo = i; cnto ++; } if (s[i] == '-') { cnt_ ++; } } cout << 'X' << endl; } int main() { int t; cin >> t; rep(_,t) { sub(); } }