#include <bits/stdc++.h>
using namespace std;
bool memory1;
typedef long long ll;
typedef unsigned long long ull;
typedef double dbe;
typedef pair<ll, ll> pll;
typedef vector<ll> vll;
typedef vector<int> vii;
#define openFile(name) freopen((name ".inp"), "r", stdin), freopen((name ".out"), "w", stdout)
#define FOR(i, a, b, x) for (int i = (a); i <= (b); i += (x))
#define ROF(i, a, b, x) for (int i = (a); i >= (b); i += (x))
#define fi first
#define se second
#define MASK(x) (1LL << (x))
#define getBit(mask, i) (((mask) >> (i)) & 1)
#define BitOn(mask) (__builtin_popcountll(mask))
const int maxN = 5e4 + 2;
//const ll maxBit = MASK(8) + 2;
const ll LOG = 16;
const ll INF18 = 1e18;
const int INF9 = 1e9;
//const ll INF3f = 0x3f3f3f3f3f3f3f3f;
const ll MOD = 1e9 + 7;
//////////////////////////////////////////////
const ll BL = 256;
struct Query12 {
int ty, id;
Query12(int t = 0, int i = 0) : ty(t), id(i) {}
};
struct Query3 {
int u, v, id;
Query3(int uu = 0, int vv = 0, int i = 0) : u(uu), v(vv), id(i) {}
};
int n, m, timeDFS;
int a[maxN];
int ans[maxN];
int sz[maxN];
int h[maxN];
int tin[maxN], tout[maxN];
int d[maxN][maxN / BL + 5]; // goc u
int f[maxN][maxN / BL + 5]; // 1 -> u
int pa[maxN][LOG + 2];
int ver[maxN];
int mark[maxN];
int colID[maxN];
map<int, int> mp;
vii stColor;
vii adj[maxN];
vector<Query12> qr12[maxN];
vector<Query3> qr3;
vii colBL;
void dfs(int u) {
tin[u] = ++timeDFS;
++d[u][colID[a[u]]];
++sz[u];
ver[tin[u]] = u;
++f[u][colID[a[u]]];
for (int v : adj[u]) if (v != pa[u][0]) {
pa[v][0] = u;
h[v] = h[u] + 1;
FOR (i, 1, LOG, 1) pa[v][i] = pa[pa[v][i - 1]][i - 1];
for (ll col : colBL) f[v][colID[col]] += f[u][colID[col]];
dfs(v);
for (ll col : colBL)
d[u][colID[col]] += d[v][colID[col]];
sz[u] += sz[v];
}
tout[u] = timeDFS;
}
void add(ll u) {
++mp[a[u]];
}
void sack(ll u, bool keep) {
int bigC = -1;
for (int v : adj[u]) if (v != pa[u][0])
if (bigC == -1 || sz[bigC] < sz[v])
bigC = v;
for (int v : adj[u]) if (v != pa[u][0] && v != bigC)
sack(v, false);
if (bigC != -1)
sack(bigC, true);
add(u);
for (int v : adj[u])
if (v != pa[u][0] && v != bigC)
FOR (i, tin[v], tout[v], 1)
add(ver[i]);
int siz;
for (Query12 &q : qr12[u]) {
int col = -1;
if (q.ty == 1) {
siz = sz[u];
if (siz < 2 * BL) {
for (pair<int, int> p : mp) // col cnt
if (p.se > siz / 2) {
col = p.fi;
break;
}
}
else
for (int c : colBL)
if (d[u][colID[c]] > siz / 2) {
col = c;
break;
}
}
else {
siz = n - sz[u];
if (siz < 2 * BL) {
for (int c : stColor) // col cnt
if (mark[c] - mp[c] > siz / 2) {
col = c;
break;
}
}
if (col == -1)
for (int c : colBL)
if (d[1][colID[c]] - d[u][colID[c]] > siz / 2) {
col = c;
break;
}
}
ans[q.id] = col;
}
if (!keep) mp.clear();
}
int lca(int u, int v) {
if (h[u] != h[v]) {
if (h[u] < h[v]) swap(u, v);
int k = h[u] - h[v];
for (int i = 0; MASK(i) <= k; ++i)
if (getBit(k, i))
u = pa[u][i];
}
if (u == v) return u;
int k = __lg(h[u]);
ROF (i, k, 0, -1)
if (pa[u][i] != pa[v][i]) {
u = pa[u][i];
v = pa[v][i];
}
return pa[u][0];
}
int pathCol(int u, int v, int p, int sz) {
map<int, int> cnt;
while (u != p) {
++cnt[a[u]];
u = pa[u][0];
}
while (v != p) {
++cnt[a[v]];
v = pa[v][0];
}
++cnt[a[p]];
for (pair<int, int> p : cnt) // col cnt
if (p.se > sz / 2)
return p.fi;
return -1;
}
void Solve() {
sort(colBL.begin(), colBL.end());
for (int col : colBL)
colID[col] = lower_bound(colBL.begin(), colBL.end(), col) - colBL.begin() + 1;
FOR (i, 1, n, 1) if (0 < mark[i] && mark[i] < BL) stColor.push_back(i);
h[1] = 1;
dfs(1);
sack(1, false);
// truy van 3
for (Query3 &q : qr3) {
int u = q.u, v = q.v;
int p = lca(u, v);
int sz = h[u] + h[v] - 2 * h[p] + 1;
ans[q.id] = -1;
if (sz <= BL * 2)
ans[q.id] = pathCol(u, v, p, sz);
else {
for (int col : colBL) {
int cID = colID[col];
int val = f[u][cID] + f[v][cID] - 2 * f[p][cID];
if (a[p] == col) ++val;
if (val > sz / 2) {
ans[q.id] = col;
break;
}
}
}
}
FOR (i, 1, m, 1) cout << ans[i] << "\n";
}
void input() {
cin >> n >> m;
FOR (i, 1, n, 1) {
cin >> a[i];
++mark[a[i]];
if (mark[a[i]] == BL) colBL.push_back(a[i]);
}
int u, v, ty;
FOR (i, 2, n, 1) {
cin >> u >> v;
adj[u].push_back(v);
adj[v].push_back(u);
}
FOR (i, 1, m, 1) {
cin >> ty;
if (ty == 1 || ty == 2) {
cin >> u;
qr12[u].emplace_back(ty, i);
}
else {
cin >> u >> v;
qr3.emplace_back(u, v, i);
}
}
Solve();
}
int main() {
openFile("TQUERY");
ios_base::sync_with_stdio(0);
cin.tie(0);
input();
//bool memory2;
//cerr << "\n\n\nTime: "<< 1000.0 * clock() / CLOCKS_PER_SEC << " ms";
//cerr << "\n\n\nMemory: "<< abs(&memory1 - &memory2) * 1.0 / MASK(20) <<" MB";
return 0;
}
// nhan0123456
#include <bits/stdc++.h>
using namespace std;
bool memory1;

typedef long long ll;
typedef unsigned long long ull;
typedef double dbe;
typedef pair<ll, ll> pll;
typedef vector<ll> vll;
typedef vector<int> vii;

#define openFile(name) freopen((name ".inp"), "r", stdin), freopen((name ".out"), "w", stdout)
#define FOR(i, a, b, x) for (int i = (a); i <= (b); i += (x))
#define ROF(i, a, b, x) for (int i = (a); i >= (b); i += (x))
#define fi first
#define se second
#define MASK(x) (1LL << (x))
#define getBit(mask, i) (((mask) >> (i)) & 1)
#define BitOn(mask) (__builtin_popcountll(mask))

const int maxN = 5e4 + 2;
//const ll maxBit = MASK(8) + 2;
const ll LOG = 16;
const ll INF18 = 1e18;
const int INF9 = 1e9;
//const ll INF3f = 0x3f3f3f3f3f3f3f3f;
const ll MOD = 1e9 + 7;
//////////////////////////////////////////////
const ll BL = 256;

struct Query12 {
    int ty, id;
    Query12(int t = 0, int i = 0) : ty(t), id(i) {}
};

struct Query3 {
    int u, v, id;
    Query3(int uu = 0, int vv = 0, int i = 0) : u(uu), v(vv), id(i) {}
};

int n, m, timeDFS;
int a[maxN];
int ans[maxN];

int sz[maxN];
int h[maxN];
int tin[maxN], tout[maxN];
int d[maxN][maxN / BL + 5]; // goc u
int f[maxN][maxN / BL + 5]; // 1 -> u
int pa[maxN][LOG + 2];
int ver[maxN];

int mark[maxN];
int colID[maxN];

map<int, int> mp;
vii stColor;
vii adj[maxN];
vector<Query12> qr12[maxN];
vector<Query3> qr3;
vii colBL;

void dfs(int u) {
    tin[u] = ++timeDFS;
    ++d[u][colID[a[u]]];
    ++sz[u];
    ver[tin[u]] = u;
    ++f[u][colID[a[u]]];

    for (int v : adj[u]) if (v != pa[u][0]) {
        pa[v][0] = u;
        h[v] = h[u] + 1;

        FOR (i, 1, LOG, 1) pa[v][i] = pa[pa[v][i - 1]][i - 1];

        for (ll col : colBL) f[v][colID[col]] += f[u][colID[col]];

        dfs(v);

        for (ll col : colBL)
            d[u][colID[col]] += d[v][colID[col]];

        sz[u] += sz[v];
    }
    tout[u] = timeDFS;
}

void add(ll u) {
    ++mp[a[u]];
}

void sack(ll u, bool keep) {
    int bigC = -1;
    for (int v : adj[u]) if (v != pa[u][0])
        if (bigC == -1 || sz[bigC] < sz[v])
            bigC = v;

    for (int v : adj[u]) if (v != pa[u][0] && v != bigC)
        sack(v, false);

    if (bigC != -1)
        sack(bigC, true);

    add(u);
    for (int v : adj[u])
        if (v != pa[u][0] && v != bigC)
            FOR (i, tin[v], tout[v], 1)
                add(ver[i]);

    int siz;
    for (Query12 &q : qr12[u]) {
        int col = -1;
        if (q.ty == 1) {
            siz = sz[u];
            if (siz < 2 * BL) {
                for (pair<int, int> p : mp) // col cnt
                    if (p.se > siz / 2) {
                        col = p.fi;
                        break;
                    }
            }
            else
                for (int c : colBL)
                    if (d[u][colID[c]] > siz / 2) {
                        col = c;
                        break;
                    }
        }
        else {
            siz = n - sz[u];
            if (siz < 2 * BL) {
                for (int c : stColor) // col cnt
                    if (mark[c] - mp[c] > siz / 2) {
                        col = c;
                        break;
                    }
            }
            if (col == -1)
                for (int c : colBL)
                    if (d[1][colID[c]] - d[u][colID[c]] > siz / 2) {
                        col = c;
                        break;
                    }
        }
        ans[q.id] = col;
    }
    if (!keep) mp.clear();
}

int lca(int u, int v) {
    if (h[u] != h[v]) {
        if (h[u] < h[v]) swap(u, v);
        int k = h[u] - h[v];
        for (int i = 0; MASK(i) <= k; ++i)
            if (getBit(k, i))
                u = pa[u][i];
    }
    if (u == v) return u;

    int k = __lg(h[u]);
    ROF (i, k, 0, -1)
        if (pa[u][i] != pa[v][i]) {
            u = pa[u][i];
            v = pa[v][i];
        }
    return pa[u][0];
}

int pathCol(int u, int v, int p, int sz) {
    map<int, int> cnt;
    while (u != p) {
        ++cnt[a[u]];
        u = pa[u][0];
    }
    while (v != p) {
        ++cnt[a[v]];
        v = pa[v][0];
    }
    ++cnt[a[p]];
    for (pair<int, int> p : cnt) // col cnt
        if (p.se > sz / 2)
            return p.fi;
    return -1;
}

void Solve() {
    sort(colBL.begin(), colBL.end());

    for (int col : colBL)
        colID[col] = lower_bound(colBL.begin(), colBL.end(), col) - colBL.begin() + 1;

    FOR (i, 1, n, 1) if (0 < mark[i] && mark[i] < BL) stColor.push_back(i);

    h[1] = 1;
    dfs(1);
    sack(1, false);
    // truy van 3
    for (Query3 &q : qr3) {
        int u = q.u, v = q.v;
        int p = lca(u, v);
        int sz = h[u] + h[v] - 2 * h[p] + 1;
        ans[q.id] = -1;

        if (sz <= BL * 2)
            ans[q.id] = pathCol(u, v, p, sz);
        else {
            for (int col : colBL) {
                int cID = colID[col];
                int val = f[u][cID] + f[v][cID] - 2 * f[p][cID];
                if (a[p] == col) ++val;

                if (val > sz / 2) {
                    ans[q.id] = col;
                    break;
                }
            }
        }
    }

    FOR (i, 1, m, 1) cout << ans[i] << "\n";
}

void input() {
    cin >> n >> m;
    FOR (i, 1, n, 1) {
        cin >> a[i];
        ++mark[a[i]];
        if (mark[a[i]] == BL) colBL.push_back(a[i]);
    }
    int u, v, ty;
    FOR (i, 2, n, 1) {
        cin >> u >> v;
        adj[u].push_back(v);
        adj[v].push_back(u);
    }
    FOR (i, 1, m, 1) {
        cin >> ty;
        if (ty == 1 || ty == 2) {
            cin >> u;
            qr12[u].emplace_back(ty, i);
        }
        else {
            cin >> u >> v;
            qr3.emplace_back(u, v, i);
        }
    }
    Solve();
}


int main() {
    openFile("TQUERY");
    ios_base::sync_with_stdio(0);
    cin.tie(0);
    input();

    //bool memory2;
    //cerr << "\n\n\nTime: "<< 1000.0 * clock() / CLOCKS_PER_SEC << " ms";
    //cerr << "\n\n\nMemory: "<< abs(&memory1 - &memory2) * 1.0 / MASK(20) <<" MB";

    return 0;
}
// nhan0123456