結果
問題 |
No.875 Range Mindex Query
|
ユーザー |
![]() |
提出日時 | 2021-04-29 20:36:16 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,280 bytes |
コンパイル時間 | 5,330 ms |
コンパイル使用メモリ | 113,316 KB |
実行使用メモリ | 41,452 KB |
最終ジャッジ日時 | 2024-07-17 13:22:43 |
合計ジャッジ時間 | 7,373 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | WA * 18 |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
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); var x = "0 " + Console.ReadLine().Trim(); string[] line = x.Split(' '); var a = Array.ConvertAll(line, int.Parse); var reva = new int[n + 1]; for (int i = 1; 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]); var r = int.Parse(line[2]); if (line[0] == "1") { var wL = a[L]; var wr = a[r]; a[L] = wr; a[r] = wL; rmq.update(L, wr); rmq.update(r, wL); var xx = reva[a[L]]; reva[a[L]] = reva[a[r]]; reva[a[r]] = xx; } else { var w2 = rmq.query(L, r+1); var p = reva[w2]; Console.WriteLine(p - L + 1); } } } }