結果
問題 | No.875 Range Mindex Query |
ユーザー | bluemegane |
提出日時 | 2021-04-29 20:39:41 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 2,263 bytes |
コンパイル時間 | 1,013 ms |
コンパイル使用メモリ | 112,780 KB |
実行使用メモリ | 44,128 KB |
最終ジャッジ日時 | 2024-07-17 13:26:04 |
合計ジャッジ時間 | 6,431 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 28 ms
25,224 KB |
testcase_01 | WA | - |
testcase_02 | WA | - |
testcase_03 | WA | - |
testcase_04 | WA | - |
testcase_05 | WA | - |
testcase_06 | WA | - |
testcase_07 | WA | - |
testcase_08 | WA | - |
testcase_09 | WA | - |
testcase_10 | WA | - |
testcase_11 | WA | - |
testcase_12 | WA | - |
testcase_13 | WA | - |
testcase_14 | WA | - |
testcase_15 | WA | - |
testcase_16 | WA | - |
testcase_17 | WA | - |
testcase_18 | WA | - |
コンパイルメッセージ
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); 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") { 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); } } } }