#include <string>
#include <vector>
#include <algorithm>
#include <numeric>
#include <set>
#include <map>
#include <queue>
#include <iostream>
#include <sstream>
#include <cstdio>
#include <cmath>
#include <ctime>
#include <cstring>
#include <cctype>
#include <cassert>
#include <limits>
#include <functional>
#include <bitset>
#define rep(i,n) for(int (i)=0;(i)<(int)(n);++(i))
#define rer(i,l,u) for(int (i)=(int)(l);(i)<=(int)(u);++(i))
#define reu(i,l,u) for(int (i)=(int)(l);(i)<(int)(u);++(i))
#if defined(_MSC_VER) || __cplusplus > 199711L
#define aut(r,v) auto r = (v)
#else
#define aut(r,v) typeof(v) r = (v)
#endif
#define each(it,o) for(aut(it, (o).begin()); it != (o).end(); ++ it)
#define all(o) (o).begin(), (o).end()
#define pb(x) push_back(x)
#define mp(x,y) make_pair((x),(y))
#define mset(m,v) memset(m,v,sizeof(m))
#define INF 0x3f3f3f3f
#define INFL 0x3f3f3f3f3f3f3f3fLL
#include<bits/stdc++.h>
#define lld long long int
#define Max 1000000+7
# define it int
using namespace std;
typedef vector<int> vi; typedef pair<int,int> pii; typedef vector<pair<int,int> > vpii;
typedef long long ll; typedef vector<long long> vl; typedef pair<long long,long long> pll; typedef vector<pair<long long,long long> > vpll;
typedef vector<string> vs; typedef long double ld;
template<typename T, typename U> inline void amin(T &x, U y) { if(y < x) x = y; }
template<typename T, typename U> inline void amax(T &x, U y) { if(x < y) x = y; }
it rupc[Max];
lld rupc7[Max];
it n; it q,i,j,k,m;
struct ass{lld y;it x;};ass bazinga[Max];
it forest[3000007];
bool check(ass hole ,ass boobs);
void make(it xxx,it l,it r);
it supckdick(it xxx,it l,it r,it nip,it x);
it supckboobs(it xxx,it l,it r,it nip,it x);
it main()
{ int kl=100000;
while (kl--){
kl-=2;
}
it l,r,up;
char c,d;
cin>>n; // sd(n);
cin>>q;//sd(q);
for(i=0;i<n;i++)
cin>>rupc[i];// sd(rupc[i]);
make(1,0,n-1);
for(i=0;i<n;i++)
{ int tt=10;
while (tt--){tt--;
}
r=supckboobs(1,0,n-1,rupc[i],i);
l=supckdick(1,0,n-1,rupc[i],i);
//printf("%d %d\n",l,r);
rupc7[i]=(1ll*(r-i+1)*(i-l+1));}
for(i=0;i<n;i++)
{
bazinga[i].x=rupc[i];
bazinga[i].y=rupc7[i];
}
sort(bazinga,bazinga+n,check);
j=0;k=bazinga[0].y;
for(i=1;i<n;i++)
{
if(bazinga[i].x==bazinga[i-1].x)
{
k+=bazinga[i].y;
}
else
{
rupc[j]=bazinga[i-1].x;
rupc7[j]=k;
k=bazinga[i].y;
j++;
}
}
rupc[j]=bazinga[i-1].x;
rupc7[j]=k;
for(i=1;i<=j;i++)
rupc7[i]+=rupc7[i-1];
// for(i=0;i<=j;i++)
// printf("%lld \n",rupc7[i]);
// for(i=0;i<=j;i++)
// {
// printf("%d %lld \n",rupc[i],rupc7[i]);
// }
//printf("1\n");
while(q--)
{
c=getchar();
c=getchar();
cin>>i;/// sd(i);
d=getchar();
d=getchar();
if(c=='=')
{
l=0;up=j;k=0;
while(l<=up)
{m=(l+up)/2;
if(rupc[m]==i)
{if(m==0){k=rupc7[0];
} else{k=rupc7[m]-rupc7[m-1];
}
break; }
if(rupc[m]<i)
{ l=m+1;
}
else{up=m-1;
} } }
else if(c=='<')
{
if(rupc[0]>=i)
k=0;
else if(rupc[j]<i)
k=rupc7[j];
else
{ l=0; up=j;
while(l<=up)
{m=(l+up)/2;
if(rupc[m]<i&&rupc[m+1]>=i)
{ k=rupc7[m];
break;}
if(rupc[m]<i)
{ l=m+1;
}
else
{ up=m-1;
}
}
}
}
else if (c=='>')
{if(rupc[0]>i)
{ k=rupc7[j];
}
else if(rupc[j]<=i)
{ k=0;
}
else
{ l=0;up=j; while(l<=up)
{m=(l+up)/2;
if(rupc[m]>i&&rupc[m-1]<=i)
{ k=rupc7[j]-rupc7[m-1];
break; }
if(rupc[m]<=i)
{ l=m+1; }
else{up=m-1;
}}}
}
if(k%2==1)
{ printf("%c",d);
}
else
{
if(d=='C')
cout<<"D";/// printf("D");
else
cout<<"C";
}
//printf("%d\n",k);
}
return 0;
}
bool check(ass hole ,ass boobs){ return hole.x<boobs.x;}
void make(it xxx,it l,it r)
{
if(l>r)
return;
if(l==r)
{
forest[xxx]=rupc[r];
return;
}
make(xxx*2,l,(l+r)/2);
make(xxx*2+1,1+(l+r)/2,r);
forest[xxx]=max(forest[xxx*2],forest[xxx*2+1]);
}
it supckboobs(it xxx,it l,it r,it nip,it x)
{
if(l>r||r<x||l>x)
return x;
if(r>=x&&l<=x)
{
if(forest[xxx]<=nip)
{
if(r<n-1){
if(rupc[r+1]>nip)
return r;
return supckboobs(1,0,n-1,nip,r+1);}
return r;
}
}
if(l==r)
{ return x;
}
it hoo=supckboobs(xxx*2,l,(l+r)/2,nip,x);
it haa=supckboobs(xxx*2+1,(l+r)/2 +1,r,nip,x);
return max(hoo,haa);
}
it supckdick(it xxx,it l,it r,it nip,it x)
{
if(l>r||r<x||l>x)
return x;
if(r>=x)
{
if(l<=x)
{if(forest[xxx]<nip)
{
if(l>0){
if(rupc[l-1]>=nip)
return l;
return supckdick(1,0,n-1,nip,l-1);}
return l;
}
}
}
if(l==r&&l!=x)
return x;
if(x>0){
if(rupc[x-1]>=nip)
return x;
return supckdick(1,0,n-1,nip,x-1);}
it hoo=supckdick(xxx*2,l,(l+r)/2,nip,x);
it haa=supckdick(xxx*2+1,(l+r)/2 +1,r,nip,x);
return min(hoo,haa);
}
#include <string>
#include <vector>
#include <algorithm>
#include <numeric>
#include <set>
#include <map>
#include <queue>
#include <iostream>
#include <sstream>
#include <cstdio>
#include <cmath>
#include <ctime>
#include <cstring>
#include <cctype>
#include <cassert>
#include <limits>
#include <functional>
#include <bitset>
#define rep(i,n) for(int (i)=0;(i)<(int)(n);++(i))
#define rer(i,l,u) for(int (i)=(int)(l);(i)<=(int)(u);++(i))
#define reu(i,l,u) for(int (i)=(int)(l);(i)<(int)(u);++(i))
#if defined(_MSC_VER) || __cplusplus > 199711L
#define aut(r,v) auto r = (v)
#else
#define aut(r,v) typeof(v) r = (v)
#endif
#define each(it,o) for(aut(it, (o).begin()); it != (o).end(); ++ it)
#define all(o) (o).begin(), (o).end()
#define pb(x) push_back(x)
#define mp(x,y) make_pair((x),(y))
#define mset(m,v) memset(m,v,sizeof(m))
#define INF 0x3f3f3f3f
#define INFL 0x3f3f3f3f3f3f3f3fLL
#include<bits/stdc++.h>
#define  lld long long int
#define Max 1000000+7
# define it int
using namespace std;
typedef vector<int> vi; typedef pair<int,int> pii; typedef vector<pair<int,int> > vpii;
typedef long long ll; typedef vector<long long> vl; typedef pair<long long,long long> pll; typedef vector<pair<long long,long long> > vpll;
typedef vector<string> vs; typedef long double ld;
template<typename T, typename U> inline void amin(T &x, U y) { if(y < x) x = y; }
template<typename T, typename U> inline void amax(T &x, U y) { if(x < y) x = y; }
it rupc[Max];
lld rupc7[Max];
it n; it q,i,j,k,m;
struct ass{lld y;it x;};ass bazinga[Max];
it forest[3000007];
bool check(ass hole ,ass boobs);
void make(it xxx,it l,it r);
it supckdick(it xxx,it l,it r,it nip,it x);
it supckboobs(it xxx,it l,it r,it nip,it x);
it main()
{   int kl=100000;
    while (kl--){
    	kl-=2;
    }
	   it l,r,up;
    char c,d;
     cin>>n; // sd(n);
    cin>>q;//sd(q);
    for(i=0;i<n;i++)
       cin>>rupc[i];// sd(rupc[i]);
    make(1,0,n-1);
    for(i=0;i<n;i++)
    { int tt=10;  
	 while (tt--){tt--;
	 }
        r=supckboobs(1,0,n-1,rupc[i],i);
        l=supckdick(1,0,n-1,rupc[i],i);
        //printf("%d %d\n",l,r);
        rupc7[i]=(1ll*(r-i+1)*(i-l+1));}
        for(i=0;i<n;i++)
        {
            bazinga[i].x=rupc[i];
            bazinga[i].y=rupc7[i];
        }
        sort(bazinga,bazinga+n,check);
        j=0;k=bazinga[0].y;
        for(i=1;i<n;i++)
        {
            if(bazinga[i].x==bazinga[i-1].x)
            {
                k+=bazinga[i].y;
            }
            else
            {
                rupc[j]=bazinga[i-1].x;
                rupc7[j]=k;
                k=bazinga[i].y;
                j++;
            }
        }
        rupc[j]=bazinga[i-1].x;
        rupc7[j]=k;
        for(i=1;i<=j;i++)
            rupc7[i]+=rupc7[i-1];
//        for(i=0;i<=j;i++)
//           printf("%lld \n",rupc7[i]);
//        for(i=0;i<=j;i++)
//        {
//            printf("%d %lld \n",rupc[i],rupc7[i]);
//        }
        //printf("1\n");
        while(q--)
        {
            c=getchar();
            c=getchar();
          cin>>i;///  sd(i);
            d=getchar();
            d=getchar();
               if(c=='=')
            {
                l=0;up=j;k=0;
                while(l<=up)
                {m=(l+up)/2;
                    if(rupc[m]==i)
                    {if(m==0){k=rupc7[0];
                            } else{k=rupc7[m]-rupc7[m-1];
                        }    
                        break; }
                    if(rupc[m]<i)
                       { l=m+1;
                       }
                    else{up=m-1;
                        } } }
           else  if(c=='<')
            {
                if(rupc[0]>=i)
                    k=0;
                else if(rupc[j]<i)
                    k=rupc7[j];
                else
                { l=0; up=j;
                    while(l<=up)
                    {m=(l+up)/2;
                        if(rupc[m]<i&&rupc[m+1]>=i)
                        { k=rupc7[m];
                            break;}
                        if(rupc[m]<i)
                          {  l=m+1;
                          }
                        else
                           { up=m-1;
                           }
                    }
                }

            }
          
            else if (c=='>')
            {if(rupc[0]>i)
                   { k=rupc7[j];
                   }
                else if(rupc[j]<=i)
                   { k=0;
                   }
                else
                { l=0;up=j; while(l<=up)
                    {m=(l+up)/2;
                        if(rupc[m]>i&&rupc[m-1]<=i)
                        { k=rupc7[j]-rupc7[m-1];
                            break; }
                        if(rupc[m]<=i)
                            {	l=m+1; }
                        else{up=m-1;
                        }}}
            }
            if(k%2==1)
                 {   printf("%c",d);
                 }
            else
            {
                if(d=='C')
                  cout<<"D";///  printf("D");
                else
                   cout<<"C";
            }
            //printf("%d\n",k);
        }
    return 0;
}
bool check(ass hole ,ass boobs){ return hole.x<boobs.x;}
void make(it xxx,it l,it r)
{
    if(l>r)
        return;
    if(l==r)
    {
        forest[xxx]=rupc[r];
        return;
    }
    make(xxx*2,l,(l+r)/2);
    make(xxx*2+1,1+(l+r)/2,r);
    forest[xxx]=max(forest[xxx*2],forest[xxx*2+1]);
}
it supckboobs(it xxx,it l,it r,it nip,it x)
{
    if(l>r||r<x||l>x)
        return x;
    if(r>=x&&l<=x)
    {
        if(forest[xxx]<=nip)
        {
            if(r<n-1){
            if(rupc[r+1]>nip)
                return r;
            return supckboobs(1,0,n-1,nip,r+1);}
            return r;
        }
    }
    if(l==r)
       { return x;
       }
    it hoo=supckboobs(xxx*2,l,(l+r)/2,nip,x);
    it haa=supckboobs(xxx*2+1,(l+r)/2 +1,r,nip,x);
    return max(hoo,haa);
}
it supckdick(it xxx,it l,it r,it nip,it x)
{
    if(l>r||r<x||l>x)
        return x;
    if(r>=x)
    {
       if(l<=x) 
	   {if(forest[xxx]<nip)
        {
            if(l>0){
            if(rupc[l-1]>=nip)
                return l;
            return supckdick(1,0,n-1,nip,l-1);}
            return l;
        }
	   }
    }
    if(l==r&&l!=x)
        return x;
    if(x>0){
        if(rupc[x-1]>=nip)
            return x;
    return supckdick(1,0,n-1,nip,x-1);}
    it hoo=supckdick(xxx*2,l,(l+r)/2,nip,x);
    it haa=supckdick(xxx*2+1,(l+r)/2 +1,r,nip,x);
    return min(hoo,haa);
}
