using System.Linq; using static System.Math; using System; public class rmq { private readonly int INTMAX = int.MaxValue; private int[] dat; private static int size; public rmq(int n) { size = 1; while (size < n) size *= 2; dat = Enumerable.Repeat(INTMAX, 2 * size - 1).ToArray(); } public void update(int i, int a) { i += size - 1; dat[i] = a; while (i > 0) { i = (i - 1) / 2; dat[i] = Min(dat[i * 2 + 1], dat[i * 2 + 2]); } } private int query(int a, int b, int k, int L, int r) { if (r <= a || b <= L) return INTMAX; if (a <= L && r <= b) return dat[k]; else { int vL = query(a, b, k * 2 + 1, L, (L + r) / 2); int vr = query(a, b, k * 2 + 2, (L + r) / 2, r); return Min(vL, vr); } } public int query(int a, int b) => query(a, b, 0, 0, size); } public class Hello { static void Main() { string[] line = Console.ReadLine().Trim().Split(' '); var n = int.Parse(line[0]); var q = int.Parse(line[1]); getAns(n, q); } static void getAns(int n, int q) { var rmq = new rmq(n + 10); string[] line = Console.ReadLine().Trim().Split(' '); var a = Array.ConvertAll(line, int.Parse); var reva = new int[n + 1]; for (int i = 0; i < n; i++) { rmq.update(i, a[i]); reva[a[i]] = i; } for (int i = 0; i < q; i++) { line = Console.ReadLine().Trim().Split(' '); var L = int.Parse(line[1]) - 1; var r = int.Parse(line[2]) - 1; if (line[0] == "1") { rmq.update(L, a[r]); rmq.update(r, a[L]); var temp= a[L]; a[L] = a[r]; a[r] = temp; temp = reva[a[L]]; reva[a[L]] = reva[a[r]]; reva[a[r]] = temp; } else { var w2 = rmq.query(L, r + 1); Console.WriteLine(reva[w2] + 1); } } } }