結果
問題 | No.875 Range Mindex Query |
ユーザー | bluemegane |
提出日時 | 2021-04-30 06:57:21 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
AC
|
実行時間 | 628 ms / 2,000 ms |
コード長 | 2,259 bytes |
コンパイル時間 | 1,328 ms |
コンパイル使用メモリ | 107,392 KB |
実行使用メモリ | 32,256 KB |
最終ジャッジ日時 | 2024-07-18 06:14:37 |
合計ジャッジ時間 | 6,778 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | AC | 24 ms
18,816 KB |
testcase_01 | AC | 30 ms
19,328 KB |
testcase_02 | AC | 34 ms
19,712 KB |
testcase_03 | AC | 24 ms
19,072 KB |
testcase_04 | AC | 30 ms
19,584 KB |
testcase_05 | AC | 27 ms
19,456 KB |
testcase_06 | AC | 28 ms
19,456 KB |
testcase_07 | AC | 29 ms
19,456 KB |
testcase_08 | AC | 28 ms
19,456 KB |
testcase_09 | AC | 28 ms
19,456 KB |
testcase_10 | AC | 30 ms
19,328 KB |
testcase_11 | AC | 386 ms
30,592 KB |
testcase_12 | AC | 356 ms
28,032 KB |
testcase_13 | AC | 273 ms
31,488 KB |
testcase_14 | AC | 289 ms
31,232 KB |
testcase_15 | AC | 403 ms
31,872 KB |
testcase_16 | AC | 557 ms
32,000 KB |
testcase_17 | AC | 628 ms
31,872 KB |
testcase_18 | AC | 597 ms
32,256 KB |
コンパイルメッセージ
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 + 1); } } } }