#include #include #include #include //#include //using namespace atcoder; using namespace std; #define reps(i, a, n) for (int i = (a); i < (int)(n); ++i) #define rep(i, n) reps(i, 0, n) #define repe(i,n) for(auto i : n) #define ALL(x) x.begin(),x.end() #define SIZE(x) ll(x.size()) #define INF32 2147483647 //2.147483647×10^{9}:32bit整数のinf #define INF64 9223372036854775807 //9.223372036854775807×10^{18}:64bit整数のinf #define MOD 1000000000 + 7 //問題による #define F first #define S second #define cYes cout << "Yes" << endl; #define cNo cout << "No" << endl; #define coutALL(x) for(auto i=x.begin();i!=--x.end();i++)cout<<(*i)<<" ";cout<<*--x.end()< #define vvi vector > #define vll vector #define vvll vector > #include #include #include #include #include #include int main(){ int n; cin >> n; string s; cin >> s; string tmp; rep(i,n){ if(s[i] == '?'){ if(i >0 &&s[i-1] == 'w'){ s[i] = 'a'; } else if(i != n-1 && (s[i+1] == 'a'|| s[i+1] == 'o')){ s[i] = 'w'; } else{ s[i] = 'n'; } } } rep(i,n){ if(s[i] == 'a' ||s[i] == 'o'){ if(i > 0 && s[i-1] == 'w') { } else{ cout << "No" << endl; return 0; } } if(s[i] == 'w'){ if(i != n-1 && (s[i+1] == 'a' || s[i+1] == 'o')) { } else{ cout << "No" << endl; return 0; } } } cout << "Yes" << endl; }