/*
* @Author: hungeazy
* @Date: 2025-11-12 22:24:27
* @Last Modified by: hungeazy
* @Last Modified time: 2025-11-12 22:47:33
*/
#include <bits/stdc++.h>
#include <ext/pb_ds/assoc_container.hpp>
#include <ext/pb_ds/tree_policy.hpp>
// #pragma GCC optimize("O3")
// #pragma GCC optimize("unroll-loops")
// #pragma GCC target("avx2,bmi,bmi2,popcnt,lzcnt")
using namespace std;
using namespace __gnu_pbds;
bool M1;
#define fast ios_base::sync_with_stdio(false); cin.tie(NULL); cout.tie(NULL);
#define int long long
#define ll long long
#define ull unsigned long long
#define sz(x) x.size()
#define sqr(x) (1LL * (x) * (x))
#define all(x) x.begin(), x.end()
#define fill(f,x) memset(f,x,sizeof(f))
#define FOR(i,l,r) for(int i=l;i<=r;i++)
#define FOD(i,r,l) for(int i=r;i>=l;i--)
#define debug(x) cout << #x << " = " << x << '\n'
#define ii pair<int,int>
#define iii pair<int,ii>
#define di pair<ii,ii>
#define vi vector<int>
#define vii vector<ii>
#define mii map<int,int>
#define fi first
#define se second
#define pb push_back
#define MOD 1000000007
#define __lcm(a,b) (1ll * ((a) / __gcd((a), (b))) * (b))
#define YES cout << "YES\n"
#define NO cout << "NO\n"
#define MASK(i) (1LL << (i))
#define c_bit(i) __builtin_popcountll(i)
#define BIT(x,i) ((x) & MASK(i))
#define SET_ON(x,i) ((x) | MASK(i))
#define SET_OFF(x,i) ((x) & ~MASK(i))
#define oo 1e18
#define name "FRIENDS"
#define endl '\n'
#define memory() cerr << abs(&M2-&M1)/1024.0/1024 << " MB" << endl
#define time() cerr << endl << "-------------Time:" << 1000.0 * clock() / CLOCKS_PER_SEC << "ms." << endl
template<typename T> bool maximize(T &res, const T &val) { if (res < val){ res = val; return true; }; return false; }
template<typename T> bool minimize(T &res, const T &val) { if (res > val){ res = val; return true; }; return false; }
template <class T> using ordered_set = tree <T, null_type, less_equal <T>, rb_tree_tag,tree_order_statistics_node_update>;
const int N = (int)2e5+10;
int n,m,deg[N],q;
ii edge[N];
struct Query {
int type,u,v;
} query[N];
namespace hungeazy {
const int M = (int)1e3+10;
int id[N],ans[M][M];
bitset<N> b[M];
bool check[N],f[N];
vi heavy;
set<int> g[N];
void add(int u, int v)
{
if (g[u].find(v) == g[u].end())
{
if (check[u] and check[v])
{
ans[id[u]][id[v]] = ans[id[v]][id[u]] = true;
b[id[u]][v] = b[id[v]][u] = true;
for (int x : heavy)
{
if (b[id[u]][x])
ans[id[v]][id[x]] = ans[id[x]][id[v]] = true;
if (b[id[v]][x])
ans[id[u]][id[x]] = ans[id[x]][id[u]] = true;
}
}
else if (check[u])
{
b[id[u]][v] = true;
for (int x : g[v])
if (check[x])
ans[id[u]][id[x]] = ans[id[x]][id[u]] = true;
}
else if (check[v])
{
b[id[v]][u] = true;
for (int x : g[u])
if (check[x])
ans[id[v]][id[x]] = ans[id[x]][id[v]] = true;
}
g[u].insert(v); g[v].insert(u);
}
}
void solve(void)
{
int S = sqrt(2*(m+q)), cnt = 0;
FOR(i,1,n)
if (deg[i] > S)
{
heavy.pb(i);
check[i] = true;
id[i] = ++cnt;
}
FOR(i,1,m)
{
auto [u,v] = edge[i];
add(u,v);
}
FOR(i,1,q)
{
int u = query[i].u, v = query[i].v;
if (query[i].type == 1)
add(u,v);
else
{
bool ok = false;
if (!check[u] and !check[v])
{
for (int x : g[u])
{
f[x] = true;
if (x == v)
{
ok = true;
break;
}
}
for (int x : g[v])
if (f[x])
{
ok = true;
break;
}
for (int x : g[u]) f[x] = false;
}
else if (!check[u])
{
for (int x : g[u])
{
f[x] = true;
if (x == v or b[id[v]][x])
{
ok = true;
break;
}
}
for (int x : g[u]) f[x] = false;
}
else if (!check[v])
{
for (int x : g[v])
{
f[x] = true;
if (x == u or b[id[u]][x])
{
ok = true;
break;
}
}
for (int x : g[v]) f[x] = false;
}
else ok = ans[id[u]][id[v]];
cout << (ok ? "YES" : "NO") << endl;
}
}
}
}
bool M2;
signed main()
{
fast;
if (fopen(name".inp","r"))
{
freopen(name".inp","r",stdin);
freopen(name".out","w",stdout);
}
cin >> n >> m;
FOR(i,1,m)
{
int u,v;
cin >> u >> v;
edge[i] = {u,v};
deg[u]++; deg[v]++;
}
cin >> q;
FOR(i,1,q)
{
cin >> query[i].type >> query[i].u >> query[i].v;
if (query[i].type == 2)
{
deg[query[i].u]++;
deg[query[i].v]++;
}
}
hungeazy::solve();
time();
memory();
return 0;
}
// ██░ ██ █ ██ ███▄ █ ▄████
//▓██░ ██▒ ██ ▓██▒ ██ ▀█ █ ██▒ ▀█▒
//▒██▀▀██░▓██ ▒██░▓██ ▀█ ██▒▒██░▄▄▄░
//░▓█ ░██ ▓▓█ ░██░▓██▒ ▐▌██▒░▓█ ██▓
//░▓█▒░██▓▒▒█████▓ ▒██░ ▓██░░▒▓███▀▒
// ▒ ░░▒░▒░▒▓▒ ▒ ▒ ░ ▒░ ▒ ▒ ░▒ ▒
// ▒ ░▒░ ░░░▒░ ░ ░ ░ ░░ ░ ▒░ ░ ░
// ░ ░░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░
// ░ ░ ░ ░ ░ ░
LyoKKiBAQXV0aG9yOiBodW5nZWF6eQoqIEBEYXRlOiAgIDIwMjUtMTEtMTIgMjI6MjQ6MjcKKiBATGFzdCBNb2RpZmllZCBieTogICBodW5nZWF6eQoqIEBMYXN0IE1vZGlmaWVkIHRpbWU6IDIwMjUtMTEtMTIgMjI6NDc6MzMKKi8KI2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxleHQvcGJfZHMvYXNzb2NfY29udGFpbmVyLmhwcD4gCiNpbmNsdWRlIDxleHQvcGJfZHMvdHJlZV9wb2xpY3kuaHBwPiAKLy8gI3ByYWdtYSBHQ0Mgb3B0aW1pemUoIk8zIikgIAovLyAjcHJhZ21hIEdDQyBvcHRpbWl6ZSgidW5yb2xsLWxvb3BzIikgIAovLyAjcHJhZ21hIEdDQyB0YXJnZXQoImF2eDIsYm1pLGJtaTIscG9wY250LGx6Y250IikgIAp1c2luZyBuYW1lc3BhY2Ugc3RkOwp1c2luZyBuYW1lc3BhY2UgX19nbnVfcGJkczsgCmJvb2wgTTE7CiNkZWZpbmUgZmFzdCBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsgY2luLnRpZShOVUxMKTsgY291dC50aWUoTlVMTCk7CiNkZWZpbmUgaW50IGxvbmcgbG9uZwojZGVmaW5lIGxsIGxvbmcgbG9uZyAKI2RlZmluZSB1bGwgdW5zaWduZWQgbG9uZyBsb25nCiNkZWZpbmUgc3ooeCkgeC5zaXplKCkKI2RlZmluZSBzcXIoeCkgKDFMTCAqICh4KSAqICh4KSkKI2RlZmluZSBhbGwoeCkgeC5iZWdpbigpLCB4LmVuZCgpCiNkZWZpbmUgZmlsbChmLHgpIG1lbXNldChmLHgsc2l6ZW9mKGYpKQojZGVmaW5lIEZPUihpLGwscikgZm9yKGludCBpPWw7aTw9cjtpKyspCiNkZWZpbmUgRk9EKGkscixsKSBmb3IoaW50IGk9cjtpPj1sO2ktLSkKI2RlZmluZSBkZWJ1Zyh4KSBjb3V0IDw8ICN4IDw8ICIgPSAiIDw8IHggPDwgJ1xuJwojZGVmaW5lIGlpIHBhaXI8aW50LGludD4KI2RlZmluZSBpaWkgcGFpcjxpbnQsaWk+CiNkZWZpbmUgZGkgcGFpcjxpaSxpaT4KI2RlZmluZSB2aSB2ZWN0b3I8aW50PgojZGVmaW5lIHZpaSB2ZWN0b3I8aWk+CiNkZWZpbmUgbWlpIG1hcDxpbnQsaW50PgojZGVmaW5lIGZpIGZpcnN0CiNkZWZpbmUgc2Ugc2Vjb25kCiNkZWZpbmUgcGIgcHVzaF9iYWNrCiNkZWZpbmUgTU9EIDEwMDAwMDAwMDcKI2RlZmluZSBfX2xjbShhLGIpICgxbGwgKiAoKGEpIC8gX19nY2QoKGEpLCAoYikpKSAqIChiKSkKI2RlZmluZSBZRVMgY291dCA8PCAiWUVTXG4iCiNkZWZpbmUgTk8gY291dCA8PCAiTk9cbiIKI2RlZmluZSBNQVNLKGkpICgxTEwgPDwgKGkpKQojZGVmaW5lIGNfYml0KGkpIF9fYnVpbHRpbl9wb3Bjb3VudGxsKGkpCiNkZWZpbmUgQklUKHgsaSkgKCh4KSAmIE1BU0soaSkpCiNkZWZpbmUgU0VUX09OKHgsaSkgKCh4KSB8IE1BU0soaSkpCiNkZWZpbmUgU0VUX09GRih4LGkpICgoeCkgJiB+TUFTSyhpKSkKI2RlZmluZSBvbyAxZTE4CiNkZWZpbmUgbmFtZSAiRlJJRU5EUyIKI2RlZmluZSBlbmRsICdcbicKI2RlZmluZSBtZW1vcnkoKSBjZXJyIDw8IGFicygmTTItJk0xKS8xMDI0LjAvMTAyNCA8PCAiIE1CIiA8PCBlbmRsCiNkZWZpbmUgdGltZSgpIGNlcnIgPDwgZW5kbCA8PCAiLS0tLS0tLS0tLS0tLVRpbWU6IiA8PCAxMDAwLjAgKiBjbG9jaygpIC8gQ0xPQ0tTX1BFUl9TRUMgPDwgIm1zLiIgPDwgZW5kbAp0ZW1wbGF0ZTx0eXBlbmFtZSBUPiBib29sIG1heGltaXplKFQgJnJlcywgY29uc3QgVCAmdmFsKSB7IGlmIChyZXMgPCB2YWwpeyByZXMgPSB2YWw7IHJldHVybiB0cnVlOyB9OyByZXR1cm4gZmFsc2U7IH0KdGVtcGxhdGU8dHlwZW5hbWUgVD4gYm9vbCBtaW5pbWl6ZShUICZyZXMsIGNvbnN0IFQgJnZhbCkgeyBpZiAocmVzID4gdmFsKXsgcmVzID0gdmFsOyByZXR1cm4gdHJ1ZTsgfTsgcmV0dXJuIGZhbHNlOyB9CnRlbXBsYXRlIDxjbGFzcyBUPiB1c2luZyBvcmRlcmVkX3NldCA9IHRyZWUgPFQsIG51bGxfdHlwZSwgbGVzc19lcXVhbCA8VD4sIHJiX3RyZWVfdGFnLHRyZWVfb3JkZXJfc3RhdGlzdGljc19ub2RlX3VwZGF0ZT47CmNvbnN0IGludCBOID0gKGludCkyZTUrMTA7CmludCBuLG0sZGVnW05dLHE7CmlpIGVkZ2VbTl07CgpzdHJ1Y3QgUXVlcnkgewoJaW50IHR5cGUsdSx2Owp9IHF1ZXJ5W05dOwoKbmFtZXNwYWNlIGh1bmdlYXp5IHsKCgljb25zdCBpbnQgTSA9IChpbnQpMWUzKzEwOwoJaW50IGlkW05dLGFuc1tNXVtNXTsKCWJpdHNldDxOPiBiW01dOwoJYm9vbCBjaGVja1tOXSxmW05dOwoJdmkgaGVhdnk7CglzZXQ8aW50PiBnW05dOwoKCXZvaWQgYWRkKGludCB1LCBpbnQgdikKCXsKCQlpZiAoZ1t1XS5maW5kKHYpID09IGdbdV0uZW5kKCkpCgkJewoJCQlpZiAoY2hlY2tbdV0gYW5kIGNoZWNrW3ZdKQoJCQl7CgkJCQlhbnNbaWRbdV1dW2lkW3ZdXSA9IGFuc1tpZFt2XV1baWRbdV1dID0gdHJ1ZTsKCQkJCWJbaWRbdV1dW3ZdID0gYltpZFt2XV1bdV0gPSB0cnVlOwoJCQkJZm9yIChpbnQgeCA6IGhlYXZ5KQoJCQkJewoJCQkJCWlmIChiW2lkW3VdXVt4XSkKCQkJCQkJYW5zW2lkW3ZdXVtpZFt4XV0gPSBhbnNbaWRbeF1dW2lkW3ZdXSA9IHRydWU7CgkJCQkJaWYgKGJbaWRbdl1dW3hdKQoJCQkJCQlhbnNbaWRbdV1dW2lkW3hdXSA9IGFuc1tpZFt4XV1baWRbdV1dID0gdHJ1ZTsKCQkJCX0KCQkJfQoJCQllbHNlIGlmIChjaGVja1t1XSkKCQkJewoJCQkJYltpZFt1XV1bdl0gPSB0cnVlOwoJCQkJZm9yIChpbnQgeCA6IGdbdl0pCgkJCQkJaWYgKGNoZWNrW3hdKQoJCQkJCQlhbnNbaWRbdV1dW2lkW3hdXSA9IGFuc1tpZFt4XV1baWRbdV1dID0gdHJ1ZTsKCQkJfQoJCQllbHNlIGlmIChjaGVja1t2XSkKCQkJewoJCQkJYltpZFt2XV1bdV0gPSB0cnVlOwoJCQkJZm9yIChpbnQgeCA6IGdbdV0pCgkJCQkJaWYgKGNoZWNrW3hdKQoJCQkJCQlhbnNbaWRbdl1dW2lkW3hdXSA9IGFuc1tpZFt4XV1baWRbdl1dID0gdHJ1ZTsKCQkJfQoJCQlnW3VdLmluc2VydCh2KTsgZ1t2XS5pbnNlcnQodSk7CgkJfQoJfQoKCXZvaWQgc29sdmUodm9pZCkKCXsKCQlpbnQgUyA9IHNxcnQoMioobStxKSksIGNudCA9IDA7CgkJRk9SKGksMSxuKQoJCQlpZiAoZGVnW2ldID4gUykKCQkJewoJCQkJaGVhdnkucGIoaSk7CgkJCQljaGVja1tpXSA9IHRydWU7CgkJCQlpZFtpXSA9ICsrY250OwoJCQl9CgkJRk9SKGksMSxtKSAKCQl7CgkJCWF1dG8gW3Usdl0gPSBlZGdlW2ldOwoJCQlhZGQodSx2KTsKCQl9CgkJRk9SKGksMSxxKQoJCXsKCQkJaW50IHUgPSBxdWVyeVtpXS51LCB2ID0gcXVlcnlbaV0udjsKCQkJaWYgKHF1ZXJ5W2ldLnR5cGUgPT0gMSkKCQkJCWFkZCh1LHYpOwoJCQllbHNlIAoJCQl7CgkJCQlib29sIG9rID0gZmFsc2U7CgkJCQlpZiAoIWNoZWNrW3VdIGFuZCAhY2hlY2tbdl0pCgkJCQl7CgkJCQkJZm9yIChpbnQgeCA6IGdbdV0pCgkJCQkJewoJCQkJCQlmW3hdID0gdHJ1ZTsKCQkJCQkJaWYgKHggPT0gdikKCQkJCQkJewoJCQkJCQkJb2sgPSB0cnVlOwoJCQkJCQkJYnJlYWs7CgkJCQkJCX0KCQkJCQl9CgkJCQkJZm9yIChpbnQgeCA6IGdbdl0pCgkJCQkJCWlmIChmW3hdKQoJCQkJCQl7CgkJCQkJCQlvayA9IHRydWU7CgkJCQkJCQlicmVhazsKCQkJCQkJfQoJCQkJCWZvciAoaW50IHggOiBnW3VdKSBmW3hdID0gZmFsc2U7CgkJCQl9CgkJCQllbHNlIGlmICghY2hlY2tbdV0pCgkJCQl7CgkJCQkJZm9yIChpbnQgeCA6IGdbdV0pCgkJCQkJewoJCQkJCQlmW3hdID0gdHJ1ZTsKCQkJCQkJaWYgKHggPT0gdiBvciBiW2lkW3ZdXVt4XSkKCQkJCQkJewoJCQkJCQkJb2sgPSB0cnVlOwoJCQkJCQkJYnJlYWs7CgkJCQkJCX0KCQkJCQl9CgkJCQkJZm9yIChpbnQgeCA6IGdbdV0pIGZbeF0gPSBmYWxzZTsKCQkJCX0KCQkJCWVsc2UgaWYgKCFjaGVja1t2XSkKCQkJCXsKCQkJCQlmb3IgKGludCB4IDogZ1t2XSkKCQkJCQl7CgkJCQkJCWZbeF0gPSB0cnVlOwoJCQkJCQlpZiAoeCA9PSB1IG9yIGJbaWRbdV1dW3hdKQoJCQkJCQl7CgkJCQkJCQlvayA9IHRydWU7CgkJCQkJCQlicmVhazsKCQkJCQkJfQoJCQkJCX0KCQkJCQlmb3IgKGludCB4IDogZ1t2XSkgZlt4XSA9IGZhbHNlOwoJCQkJfQoJCQkJZWxzZSBvayA9IGFuc1tpZFt1XV1baWRbdl1dOwoJCQkJY291dCA8PCAob2sgPyAiWUVTIiA6ICJOTyIpIDw8IGVuZGw7CgkJCX0KCQl9Cgl9CgkKfQoKYm9vbCBNMjsKc2lnbmVkIG1haW4oKQp7CiAgICBmYXN0OwogICAgaWYgKGZvcGVuKG5hbWUiLmlucCIsInIiKSkKICAgIHsKICAgIAlmcmVvcGVuKG5hbWUiLmlucCIsInIiLHN0ZGluKTsKICAgIAlmcmVvcGVuKG5hbWUiLm91dCIsInciLHN0ZG91dCk7CiAgICB9CiAgICBjaW4gPj4gbiA+PiBtOwogICAgRk9SKGksMSxtKQogICAgewogICAgCWludCB1LHY7CiAgICAJY2luID4+IHUgPj4gdjsKICAgIAllZGdlW2ldID0ge3Usdn07CiAgICAJZGVnW3VdKys7IGRlZ1t2XSsrOwogICAgfQogICAgY2luID4+IHE7CiAgICBGT1IoaSwxLHEpIAogICAgewogICAgCWNpbiA+PiBxdWVyeVtpXS50eXBlID4+IHF1ZXJ5W2ldLnUgPj4gcXVlcnlbaV0udjsKICAgIAlpZiAocXVlcnlbaV0udHlwZSA9PSAyKQogICAgCXsKICAgIAkJZGVnW3F1ZXJ5W2ldLnVdKys7CiAgICAJCWRlZ1txdWVyeVtpXS52XSsrOwogICAgCX0KICAgIH0KICAgIGh1bmdlYXp5Ojpzb2x2ZSgpOwogICAgdGltZSgpOwogICAgbWVtb3J5KCk7CiAgICByZXR1cm4gMDsKfQovLyDilojilojilpEg4paI4paIICDiloggICAg4paI4paIICDilojilojilojiloQgICAg4paIICAg4paE4paI4paI4paI4paICi8v4paT4paI4paI4paRIOKWiOKWiOKWkiDilojiloggIOKWk+KWiOKWiOKWkiDilojilogg4paA4paIICAg4paIICDilojilojilpIg4paA4paI4paSCi8v4paS4paI4paI4paA4paA4paI4paI4paR4paT4paI4paIICDilpLilojilojilpHilpPilojiloggIOKWgOKWiCDilojilojilpLilpLilojilojilpHiloTiloTiloTilpEKLy/ilpHilpPilogg4paR4paI4paIIOKWk+KWk+KWiCAg4paR4paI4paI4paR4paT4paI4paI4paSICDilpDilozilojilojilpLilpHilpPiloggIOKWiOKWiOKWkwovL+KWkeKWk+KWiOKWkuKWkeKWiOKWiOKWk+KWkuKWkuKWiOKWiOKWiOKWiOKWiOKWkyDilpLilojilojilpEgICDilpPilojilojilpHilpHilpLilpPilojilojilojiloDilpIKLy8g4paSIOKWkeKWkeKWkuKWkeKWkuKWkeKWkuKWk+KWkiDilpIg4paSIOKWkSDilpLilpEgICDilpIg4paSICDilpHilpIgICDilpIKLy8g4paSIOKWkeKWkuKWkSDilpHilpHilpHilpLilpEg4paRIOKWkSDilpEg4paR4paRICAg4paRIOKWkuKWkSAg4paRICAg4paRCi8vIOKWkSAg4paR4paRIOKWkSDilpHilpHilpEg4paRIOKWkSAgICDilpEgICDilpEg4paRIOKWkSDilpEgICDilpEKLy8g4paRICDilpEgIOKWkSAgIOKWkSAgICAgICAgICAgICAg4paRICAgICAgIOKWkQ==