#include namespace { #pragma GCC diagnostic ignored "-Wunused-function" #include #pragma GCC diagnostic warning "-Wunused-function" using namespace std; using namespace atcoder; #define rep(i,n) for(int i = 0; i < (int)(n); i++) #define rrep(i,n) for(int i = (int)(n) - 1; i >= 0; i--) #define all(x) begin(x), end(x) #define rall(x) rbegin(x), rend(x) template bool chmax(T& a, const T& b) { if (a < b) { a = b; return true; } else return false; } template bool chmin(T& a, const T& b) { if (b < a) { a = b; return true; } else return false; } using ll = long long; using P = pair; using VI = vector; using VVI = vector; using VL = vector; using VVL = vector; // add diff struct S { bool v[26]; }; S op(S x, S y) { S res; rep(i, 26) res.v[i] = x.v[i] & y.v[i]; return res; } S e() { S res; rep(i, 26) res.v[i] = true; return res; } int composition(int f, int g) { return f + g; } int id() { return 0; } S mapping(int f, S x) { f %= 26; if (f < 0) f += 26; if (f == 0) return x; rotate(x.v, x.v + f, x.v + 26); return x; } } int main() { ios::sync_with_stdio(false); cin.tie(0); string s, t; cin >> s >> t; int q; cin >> q; int mx = max(s.size(), t.size()); vector init(mx); rep(i, mx) { S v; if (i >= ssize(s) || i >= ssize(t)) { rep(i, 26) v.v[i] = false; } else { rep(i, 26) v.v[i] = false; int diff = (t[i] - s[i] + 52) % 26; v.v[diff] = true; } init[i] = v; } lazy_segtree seg(init); fenwick_tree add_s(ssize(s) + 1), add_t(ssize(t) + 1); while (q--) { int type; cin >> type; if (type == 1) { int l, r, x; cin >> l >> r >> x; l--; seg.apply(l, r, x); add_s.add(l, x); add_s.add(r, -x); } else if (type == 2) { int l, r, x; cin >> l >> r >> x; l--; seg.apply(l, r, -x); add_t.add(l, x); add_t.add(r, -x); } else { int p; cin >> p; p--; int r = seg.max_right(p, [](const S& s) { return s.v[0]; }); if (r == ssize(s)) { if (r == ssize(t)) { cout << "Equals\n"; } else { cout << "Lesser\n"; } } else if (r == ssize(t)) { cout << "Greater\n"; } else { int sx = (s[r] - 'a' + add_s.sum(0, r + 1)) % 26; int tx = (t[r] - 'a' + add_t.sum(0, r + 1)) % 26; cout << (sx < tx ? "Lesser\n" : "Greater\n"); } } } }