#include<bits/stdc++.h>
using namespace std;
typedef long long int ll;
#define MOD 1000000007
#define pb push_back
#define vi vector<int>
#define vl vector<ll>
#define F first
#define S second
#define yes cout<<"YES"<<'\n';
#define no cout<<"NO"<<'\n';
#define endl "\n"
#define all(v) v.begin(),v.end()
#define print(v) for(auto it:v) cout<<it<<" "; cout<<endl;
#define srt(v) sort(v.begin(),v.end());
#define rsrt(v) sort(v.rbegin(),v.rend());
#define gcd(a,b) __gcd(a,b)
#define lcm(a,b) (a*b)/gcd(a,b)
#define PI 2*acos(0.0)
#define pr pair<int,int>
#define Tasrik ios_base::sync_with_stdio(0); cin.tie(0); cout.tie(0);
int main ()
{
Tasrik;
ll t=1,n,q,d;
cin>>t;
while(t--)
{
string s;
cin>>s>>q;
deque<char> dq(all(s));
ll f=0;
while(q--)
{
ll x;
cin>>x;
if(x==1)
{
f^=1;
}
else
{
char c;
cin>>d>>c;
if( (d==1 && !f) || (d==2 && f))
dq.push_front(c);
else
dq.pb(c);
}
}
if(f)
{
for( auto it=dq.rbegin(); it!=dq.rend(); it++)
cout<<*it;
}
else
{
for( auto it=dq.begin(); it!=dq.end(); it++)
cout<<*it;
}
cout<<endl;
}
}