#pragma GCC optimize("Ofast") #include using namespace std; typedef long long ll; //#define EPS (1e-7) #define INF (1e9) #define rep(i, n) for(int i = 0; i < (int)(n); i++) #define all(x) x.begin(),x.end() const double PI = acos(-1); const ll MOD = 1000000007; // const ll MOD = 998244353; template inline bool chmax(T &a, T b) { if(a < b) { a = b; return true; } return false; } template inline bool chmin(T &a, T b) { if(a > b) { a = b; return true; } return false; } /////////////////////////////////////////////////////////////// struct SegmentTree { int N; vector> node; SegmentTree(vector v) { N = 1; int sz = v.size(); while (N < sz) N *= 2; node.assign(2*N,make_pair(N+1,N+1)); for (int i = 0; i < sz; i++) node[i+N] = make_pair(v[i],i+1); for (int i = N-1; i > 0; i--) { if (node[i<<1|0].first < node[i<<1|1].first) { node[i] = node[i<<1|0]; } else node[i] = node[i<<1|1]; } } void update(int x, int y) { x += N; y += N; swap(node[x].first,node[y].first); while (x > 1) { x >>= 1; if (node[x<<1|0].first < node[x<<1|1].first) { node[x] = node[x<<1|0]; } else node[x] = node[x<<1|1]; } while (y > 1) { y >>= 1; if (node[y<<1|0].first < node[y<<1|1].first) { node[y] = node[y<<1|0]; } else node[y] = node[y<<1|1]; } } pair getmin(int a, int b, int k = 1, int l = 0, int r = -1) { if (r < 0) r = N; if (a >= r || b <= l) return make_pair(N+1,N+1); if (a <= l && r <= b) return node[k]; int vl,ln,vr,rn; tie(vl,ln) = getmin(a,b,k<<1|0,l,(l+r)/2); tie(vr,rn) = getmin(a,b,k<<1|1,(l+r)/2,r); if (vl < vr) return make_pair(vl,ln); else return make_pair(vr,rn); } }; int main() { ios::sync_with_stdio(false); cin.tie(nullptr); int N,Q; cin >> N >> Q; vector A(N); rep(i,N) cin >> A[i]; SegmentTree sg(A); rep(i,Q) { int q,l,r; cin >> q >> l >> r; if (q == 1) sg.update(l-1,r-1); else cout << sg.getmin(l-1,r).second << endl; } }