/*
* @Author: hungeazy
* @Date: 2025-11-12 22:24:27
* @Last Modified by: hungeazy
* @Last Modified time: 2025-11-12 23:04:25
*/
#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];
// Olympic 30/4 - Khối 11 - 2021
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,g[N];
map<ii,bool> have;
void add(int u, int v)
{
if (!have[{u,v}])
{
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].pb(v); g[v].pb(u);
have[{u,v}] = have[{v,u}] = true;
}
}
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;
}
// ██░ ██ █ ██ ███▄ █ ▄████
//▓██░ ██▒ ██ ▓██▒ ██ ▀█ █ ██▒ ▀█▒
//▒██▀▀██░▓██ ▒██░▓██ ▀█ ██▒▒██░▄▄▄░
//░▓█ ░██ ▓▓█ ░██░▓██▒ ▐▌██▒░▓█ ██▓
//░▓█▒░██▓▒▒█████▓ ▒██░ ▓██░░▒▓███▀▒
// ▒ ░░▒░▒░▒▓▒ ▒ ▒ ░ ▒░ ▒ ▒ ░▒ ▒
// ▒ ░▒░ ░░░▒░ ░ ░ ░ ░░ ░ ▒░ ░ ░
// ░ ░░ ░ ░░░ ░ ░ ░ ░ ░ ░ ░ ░
// ░ ░ ░ ░ ░ ░
LyoKKiBAQXV0aG9yOiBodW5nZWF6eQoqIEBEYXRlOiAgIDIwMjUtMTEtMTIgMjI6MjQ6MjcKKiBATGFzdCBNb2RpZmllZCBieTogICBodW5nZWF6eQoqIEBMYXN0IE1vZGlmaWVkIHRpbWU6IDIwMjUtMTEtMTIgMjM6MDQ6MjUKKi8KI2luY2x1ZGUgPGJpdHMvc3RkYysrLmg+CiNpbmNsdWRlIDxleHQvcGJfZHMvYXNzb2NfY29udGFpbmVyLmhwcD4gCiNpbmNsdWRlIDxleHQvcGJfZHMvdHJlZV9wb2xpY3kuaHBwPiAKLy8gI3ByYWdtYSBHQ0Mgb3B0aW1pemUoIk8zIikgIAovLyAjcHJhZ21hIEdDQyBvcHRpbWl6ZSgidW5yb2xsLWxvb3BzIikgIAovLyAjcHJhZ21hIEdDQyB0YXJnZXQoImF2eDIsYm1pLGJtaTIscG9wY250LGx6Y250IikgIAp1c2luZyBuYW1lc3BhY2Ugc3RkOwp1c2luZyBuYW1lc3BhY2UgX19nbnVfcGJkczsgCmJvb2wgTTE7CiNkZWZpbmUgZmFzdCBpb3NfYmFzZTo6c3luY193aXRoX3N0ZGlvKGZhbHNlKTsgY2luLnRpZShOVUxMKTsgY291dC50aWUoTlVMTCk7CiNkZWZpbmUgaW50IGxvbmcgbG9uZwojZGVmaW5lIGxsIGxvbmcgbG9uZyAKI2RlZmluZSB1bGwgdW5zaWduZWQgbG9uZyBsb25nCiNkZWZpbmUgc3ooeCkgeC5zaXplKCkKI2RlZmluZSBzcXIoeCkgKDFMTCAqICh4KSAqICh4KSkKI2RlZmluZSBhbGwoeCkgeC5iZWdpbigpLCB4LmVuZCgpCiNkZWZpbmUgZmlsbChmLHgpIG1lbXNldChmLHgsc2l6ZW9mKGYpKQojZGVmaW5lIEZPUihpLGwscikgZm9yKGludCBpPWw7aTw9cjtpKyspCiNkZWZpbmUgRk9EKGkscixsKSBmb3IoaW50IGk9cjtpPj1sO2ktLSkKI2RlZmluZSBkZWJ1Zyh4KSBjb3V0IDw8ICN4IDw8ICIgPSAiIDw8IHggPDwgJ1xuJwojZGVmaW5lIGlpIHBhaXI8aW50LGludD4KI2RlZmluZSBpaWkgcGFpcjxpbnQsaWk+CiNkZWZpbmUgZGkgcGFpcjxpaSxpaT4KI2RlZmluZSB2aSB2ZWN0b3I8aW50PgojZGVmaW5lIHZpaSB2ZWN0b3I8aWk+CiNkZWZpbmUgbWlpIG1hcDxpbnQsaW50PgojZGVmaW5lIGZpIGZpcnN0CiNkZWZpbmUgc2Ugc2Vjb25kCiNkZWZpbmUgcGIgcHVzaF9iYWNrCiNkZWZpbmUgTU9EIDEwMDAwMDAwMDcKI2RlZmluZSBfX2xjbShhLGIpICgxbGwgKiAoKGEpIC8gX19nY2QoKGEpLCAoYikpKSAqIChiKSkKI2RlZmluZSBZRVMgY291dCA8PCAiWUVTXG4iCiNkZWZpbmUgTk8gY291dCA8PCAiTk9cbiIKI2RlZmluZSBNQVNLKGkpICgxTEwgPDwgKGkpKQojZGVmaW5lIGNfYml0KGkpIF9fYnVpbHRpbl9wb3Bjb3VudGxsKGkpCiNkZWZpbmUgQklUKHgsaSkgKCh4KSAmIE1BU0soaSkpCiNkZWZpbmUgU0VUX09OKHgsaSkgKCh4KSB8IE1BU0soaSkpCiNkZWZpbmUgU0VUX09GRih4LGkpICgoeCkgJiB+TUFTSyhpKSkKI2RlZmluZSBvbyAxZTE4CiNkZWZpbmUgbmFtZSAiRlJJRU5EUyIKI2RlZmluZSBlbmRsICdcbicKI2RlZmluZSBtZW1vcnkoKSBjZXJyIDw8IGFicygmTTItJk0xKS8xMDI0LjAvMTAyNCA8PCAiIE1CIiA8PCBlbmRsCiNkZWZpbmUgdGltZSgpIGNlcnIgPDwgZW5kbCA8PCAiLS0tLS0tLS0tLS0tLVRpbWU6IiA8PCAxMDAwLjAgKiBjbG9jaygpIC8gQ0xPQ0tTX1BFUl9TRUMgPDwgIm1zLiIgPDwgZW5kbAp0ZW1wbGF0ZTx0eXBlbmFtZSBUPiBib29sIG1heGltaXplKFQgJnJlcywgY29uc3QgVCAmdmFsKSB7IGlmIChyZXMgPCB2YWwpeyByZXMgPSB2YWw7IHJldHVybiB0cnVlOyB9OyByZXR1cm4gZmFsc2U7IH0KdGVtcGxhdGU8dHlwZW5hbWUgVD4gYm9vbCBtaW5pbWl6ZShUICZyZXMsIGNvbnN0IFQgJnZhbCkgeyBpZiAocmVzID4gdmFsKXsgcmVzID0gdmFsOyByZXR1cm4gdHJ1ZTsgfTsgcmV0dXJuIGZhbHNlOyB9CnRlbXBsYXRlIDxjbGFzcyBUPiB1c2luZyBvcmRlcmVkX3NldCA9IHRyZWUgPFQsIG51bGxfdHlwZSwgbGVzc19lcXVhbCA8VD4sIHJiX3RyZWVfdGFnLHRyZWVfb3JkZXJfc3RhdGlzdGljc19ub2RlX3VwZGF0ZT47CmNvbnN0IGludCBOID0gKGludCkyZTUrMTA7CmludCBuLG0sZGVnW05dLHE7CmlpIGVkZ2VbTl07CgpzdHJ1Y3QgUXVlcnkgewoJaW50IHR5cGUsdSx2Owp9IHF1ZXJ5W05dOwovLyBPbHltcGljIDMwLzQgLSBLaOG7kWkgMTEgLSAyMDIxCm5hbWVzcGFjZSBodW5nZWF6eSB7CgoJY29uc3QgaW50IE0gPSAoaW50KTFlMysxMDsKCWludCBpZFtOXSxhbnNbTV1bTV07CgliaXRzZXQ8Tj4gYltNXTsKCWJvb2wgY2hlY2tbTl0sZltOXTsKCXZpIGhlYXZ5LGdbTl07CgltYXA8aWksYm9vbD4gaGF2ZTsKCgl2b2lkIGFkZChpbnQgdSwgaW50IHYpCgl7CgkJaWYgKCFoYXZlW3t1LHZ9XSkKCQl7CgkJCWlmIChjaGVja1t1XSBhbmQgY2hlY2tbdl0pCgkJCXsKCQkJCWFuc1tpZFt1XV1baWRbdl1dID0gYW5zW2lkW3ZdXVtpZFt1XV0gPSB0cnVlOwoJCQkJYltpZFt1XV1bdl0gPSBiW2lkW3ZdXVt1XSA9IHRydWU7CgkJCQlmb3IgKGludCB4IDogaGVhdnkpCgkJCQl7CgkJCQkJaWYgKGJbaWRbdV1dW3hdKQoJCQkJCQlhbnNbaWRbdl1dW2lkW3hdXSA9IGFuc1tpZFt4XV1baWRbdl1dID0gdHJ1ZTsKCQkJCQlpZiAoYltpZFt2XV1beF0pCgkJCQkJCWFuc1tpZFt1XV1baWRbeF1dID0gYW5zW2lkW3hdXVtpZFt1XV0gPSB0cnVlOwoJCQkJfQoJCQl9CgkJCWVsc2UgaWYgKGNoZWNrW3VdKQoJCQl7CgkJCQliW2lkW3VdXVt2XSA9IHRydWU7CgkJCQlmb3IgKGludCB4IDogZ1t2XSkKCQkJCQlpZiAoY2hlY2tbeF0pCgkJCQkJCWFuc1tpZFt1XV1baWRbeF1dID0gYW5zW2lkW3hdXVtpZFt1XV0gPSB0cnVlOwoJCQl9CgkJCWVsc2UgaWYgKGNoZWNrW3ZdKQoJCQl7CgkJCQliW2lkW3ZdXVt1XSA9IHRydWU7CgkJCQlmb3IgKGludCB4IDogZ1t1XSkKCQkJCQlpZiAoY2hlY2tbeF0pCgkJCQkJCWFuc1tpZFt2XV1baWRbeF1dID0gYW5zW2lkW3hdXVtpZFt2XV0gPSB0cnVlOwoJCQl9CgkJCWdbdV0ucGIodik7IGdbdl0ucGIodSk7CgkJCWhhdmVbe3Usdn1dID0gaGF2ZVt7dix1fV0gPSB0cnVlOwoJCX0KCX0KCgl2b2lkIHNvbHZlKHZvaWQpCgl7CgkJaW50IFMgPSBzcXJ0KDIqKG0rcSkpLCBjbnQgPSAwOwoJCUZPUihpLDEsbikKCQkJaWYgKGRlZ1tpXSA+IFMpCgkJCXsKCQkJCWhlYXZ5LnBiKGkpOwoJCQkJY2hlY2tbaV0gPSB0cnVlOwoJCQkJaWRbaV0gPSArK2NudDsKCQkJfQoJCUZPUihpLDEsbSkgCgkJewoJCQlhdXRvIFt1LHZdID0gZWRnZVtpXTsKCQkJYWRkKHUsdik7CgkJfQoJCUZPUihpLDEscSkKCQl7CgkJCWludCB1ID0gcXVlcnlbaV0udSwgdiA9IHF1ZXJ5W2ldLnY7CgkJCWlmIChxdWVyeVtpXS50eXBlID09IDEpCgkJCQlhZGQodSx2KTsKCQkJZWxzZSAKCQkJewoJCQkJYm9vbCBvayA9IGZhbHNlOwoJCQkJaWYgKCFjaGVja1t1XSBhbmQgIWNoZWNrW3ZdKQoJCQkJewoJCQkJCWZvciAoaW50IHggOiBnW3VdKQoJCQkJCXsKCQkJCQkJZlt4XSA9IHRydWU7CgkJCQkJCWlmICh4ID09IHYpCgkJCQkJCXsKCQkJCQkJCW9rID0gdHJ1ZTsKCQkJCQkJCWJyZWFrOwoJCQkJCQl9CgkJCQkJfQoJCQkJCWZvciAoaW50IHggOiBnW3ZdKQoJCQkJCQlpZiAoZlt4XSkKCQkJCQkJewoJCQkJCQkJb2sgPSB0cnVlOwoJCQkJCQkJYnJlYWs7CgkJCQkJCX0KCQkJCQlmb3IgKGludCB4IDogZ1t1XSkgZlt4XSA9IGZhbHNlOwoJCQkJfQoJCQkJZWxzZSBpZiAoIWNoZWNrW3VdKQoJCQkJewoJCQkJCWZvciAoaW50IHggOiBnW3VdKQoJCQkJCXsKCQkJCQkJZlt4XSA9IHRydWU7CgkJCQkJCWlmICh4ID09IHYgb3IgYltpZFt2XV1beF0pCgkJCQkJCXsKCQkJCQkJCW9rID0gdHJ1ZTsKCQkJCQkJCWJyZWFrOwoJCQkJCQl9CgkJCQkJfQoJCQkJCWZvciAoaW50IHggOiBnW3VdKSBmW3hdID0gZmFsc2U7CgkJCQl9CgkJCQllbHNlIGlmICghY2hlY2tbdl0pCgkJCQl7CgkJCQkJZm9yIChpbnQgeCA6IGdbdl0pCgkJCQkJewoJCQkJCQlmW3hdID0gdHJ1ZTsKCQkJCQkJaWYgKHggPT0gdSBvciBiW2lkW3VdXVt4XSkKCQkJCQkJewoJCQkJCQkJb2sgPSB0cnVlOwoJCQkJCQkJYnJlYWs7CgkJCQkJCX0KCQkJCQl9CgkJCQkJZm9yIChpbnQgeCA6IGdbdl0pIGZbeF0gPSBmYWxzZTsKCQkJCX0KCQkJCWVsc2Ugb2sgPSBhbnNbaWRbdV1dW2lkW3ZdXTsKCQkJCWNvdXQgPDwgKG9rID8gIllFUyIgOiAiTk8iKSA8PCBlbmRsOwoJCQl9CgkJfQoJfQoJCn0KCmJvb2wgTTI7CnNpZ25lZCBtYWluKCkKewogICAgZmFzdDsKICAgIGlmIChmb3BlbihuYW1lIi5pbnAiLCJyIikpCiAgICB7CiAgICAJZnJlb3BlbihuYW1lIi5pbnAiLCJyIixzdGRpbik7CiAgICAJZnJlb3BlbihuYW1lIi5vdXQiLCJ3IixzdGRvdXQpOwogICAgfQogICAgY2luID4+IG4gPj4gbTsKICAgIEZPUihpLDEsbSkKICAgIHsKICAgIAlpbnQgdSx2OwogICAgCWNpbiA+PiB1ID4+IHY7CiAgICAJZWRnZVtpXSA9IHt1LHZ9OwogICAgCWRlZ1t1XSsrOyBkZWdbdl0rKzsKICAgIH0KICAgIGNpbiA+PiBxOwogICAgRk9SKGksMSxxKSAKICAgIHsKICAgIAljaW4gPj4gcXVlcnlbaV0udHlwZSA+PiBxdWVyeVtpXS51ID4+IHF1ZXJ5W2ldLnY7CiAgICAJaWYgKHF1ZXJ5W2ldLnR5cGUgPT0gMikKICAgIAl7CiAgICAJCWRlZ1txdWVyeVtpXS51XSsrOwogICAgCQlkZWdbcXVlcnlbaV0udl0rKzsKICAgIAl9CiAgICB9CiAgICBodW5nZWF6eTo6c29sdmUoKTsKICAgIHRpbWUoKTsKICAgIG1lbW9yeSgpOwogICAgcmV0dXJuIDA7Cn0KLy8g4paI4paI4paRIOKWiOKWiCAg4paIICAgIOKWiOKWiCAg4paI4paI4paI4paEICAgIOKWiCAgIOKWhOKWiOKWiOKWiOKWiAovL+KWk+KWiOKWiOKWkSDilojilojilpIg4paI4paIICDilpPilojilojilpIg4paI4paIIOKWgOKWiCAgIOKWiCAg4paI4paI4paSIOKWgOKWiOKWkgovL+KWkuKWiOKWiOKWgOKWgOKWiOKWiOKWkeKWk+KWiOKWiCAg4paS4paI4paI4paR4paT4paI4paIICDiloDilogg4paI4paI4paS4paS4paI4paI4paR4paE4paE4paE4paRCi8v4paR4paT4paIIOKWkeKWiOKWiCDilpPilpPiloggIOKWkeKWiOKWiOKWkeKWk+KWiOKWiOKWkiAg4paQ4paM4paI4paI4paS4paR4paT4paIICDilojilojilpMKLy/ilpHilpPilojilpLilpHilojilojilpPilpLilpLilojilojilojilojilojilpMg4paS4paI4paI4paRICAg4paT4paI4paI4paR4paR4paS4paT4paI4paI4paI4paA4paSCi8vIOKWkiDilpHilpHilpLilpHilpLilpHilpLilpPilpIg4paSIOKWkiDilpEg4paS4paRICAg4paSIOKWkiAg4paR4paSICAg4paSCi8vIOKWkiDilpHilpLilpEg4paR4paR4paR4paS4paRIOKWkSDilpEg4paRIOKWkeKWkSAgIOKWkSDilpLilpEgIOKWkSAgIOKWkQovLyDilpEgIOKWkeKWkSDilpEg4paR4paR4paRIOKWkSDilpEgICAg4paRICAg4paRIOKWkSDilpEg4paRICAg4paRCi8vIOKWkSAg4paRICDilpEgICDilpEgICAgICAgICAgICAgIOKWkSAgICAgICDilpE=