結果
問題 | No.971 いたずらっ子 |
ユーザー | keymoon |
提出日時 | 2020-01-17 21:34:36 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
MLE
|
実行時間 | - |
コード長 | 4,489 bytes |
コンパイル時間 | 1,200 ms |
コンパイル使用メモリ | 119,176 KB |
実行使用メモリ | 988,364 KB |
最終ジャッジ日時 | 2024-06-25 18:53:44 |
合計ジャッジ時間 | 7,987 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge3 |
(要ログイン)
テストケース
テストケース表示入力 | 結果 | 実行時間 実行使用メモリ |
---|---|---|
testcase_00 | MLE | - |
testcase_01 | -- | - |
testcase_02 | -- | - |
testcase_03 | -- | - |
testcase_04 | -- | - |
testcase_05 | -- | - |
testcase_06 | -- | - |
testcase_07 | -- | - |
testcase_08 | -- | - |
testcase_09 | -- | - |
testcase_10 | -- | - |
testcase_11 | -- | - |
testcase_12 | -- | - |
testcase_13 | -- | - |
testcase_14 | -- | - |
testcase_15 | -- | - |
testcase_16 | -- | - |
testcase_17 | -- | - |
testcase_18 | -- | - |
testcase_19 | -- | - |
testcase_20 | -- | - |
testcase_21 | -- | - |
testcase_22 | -- | - |
testcase_23 | -- | - |
testcase_24 | -- | - |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
using System; using System.Collections; using System.Collections.Generic; using System.Diagnostics; using System.IO; using System.Linq; using System.Numerics; using System.Text; using System.Text.RegularExpressions; using System.Threading.Tasks; using static System.Math; using MethodImplAttribute = System.Runtime.CompilerServices.MethodImplAttribute; using MethodImplOptions = System.Runtime.CompilerServices.MethodImplOptions; public static class P { public static void Main() { var hw = Console.ReadLine().Split().Select(int.Parse).ToArray(); var h = hw[0]; var w = hw[1]; var map = Enumerable.Repeat(0, h).Select(_ => Console.ReadLine()).ToArray().SelectMany(x => x).ToArray(); List<int>[] graph = Enumerable.Repeat(0, h * w).Select(_ => new List<int>()).ToArray(); for (int i = 0; i < h - 1; i++) for (int j = 0; j < w; j++) { var id = i * w + j; graph[id].Add(id + w); graph[id + w].Add(id); } for (int i = 0; i < h; i++) for (int j = 0; j < w - 1; j++) { var id = i * w + j; graph[id].Add(id + 1); graph[id + 1].Add(id); } var shortest = Enumerable.Repeat(1L << 60, graph.Length).ToArray(); PriorityQueue<Tuple<int, int>, int> pqueue = new PriorityQueue<Tuple<int, int>, int>(x => x.Item2); pqueue.Push(new Tuple<int, int>(0, 0)); while (0 < pqueue.Count) { var item = pqueue.Pop(); if (shortest[item.Item1] != 1L << 60) continue; shortest[item.Item1] = item.Item2; foreach (var elem in graph[item.Item1]) { if (shortest[elem] != 1L << 60) continue; pqueue.Push(new Tuple<int, int>(elem, item.Item2 + 1 + (map[elem] == 'k' ? GetDist(elem, w) : 0))); } } Console.WriteLine(shortest.Last()); } static int GetDist(int id, int w) => id / w + id % w; } class PriorityQueue<TValue, TKey> where TKey : IComparable<TKey> { public int Count { get; private set; } private Func<TValue, TKey> KeySelector; private bool Descendance; private TValue[] data = new TValue[65536]; private TKey[] keys = new TKey[65536]; [MethodImpl(MethodImplOptions.AggressiveInlining)] public PriorityQueue(Func<TValue, TKey> keySelector, bool descendance = false) { KeySelector = keySelector; Descendance = descendance; } public TValue Top { [MethodImpl(MethodImplOptions.AggressiveInlining)] get { ValidateNonEmpty(); return data[1]; } } [MethodImpl(MethodImplOptions.AggressiveInlining)] public TValue Pop() { var top = Top; var item = data[Count]; var key = keys[Count--]; int index = 1; while (true) { if ((index << 1) >= Count) { if (index << 1 > Count) break; if (key.CompareTo(keys[index << 1]) > 0 ^ Descendance) { data[index] = data[index << 1]; keys[index] = keys[index << 1]; index <<= 1; } else break; } else { var nextIndex = keys[index << 1].CompareTo(keys[(index << 1) + 1]) <= 0 ^ Descendance ? (index << 1) : (index << 1) + 1; if (key.CompareTo(keys[nextIndex]) > 0 ^ Descendance) { data[index] = data[nextIndex]; keys[index] = keys[nextIndex]; index = nextIndex; } else break; } } data[index] = item; keys[index] = key; return top; } [MethodImpl(MethodImplOptions.AggressiveInlining)] public void Push(TValue item) { var key = KeySelector(item); int index = ++Count; if (data.Length == Count) Extend(data.Length * 2); while ((index >> 1) != 0) { if (keys[index >> 1].CompareTo(key) > 0 ^ Descendance) { data[index] = data[index >> 1]; keys[index] = keys[index >> 1]; index >>= 1; } else break; } data[index] = item; keys[index] = key; } [MethodImpl(MethodImplOptions.AggressiveInlining)] private void Extend(int newSize) { TValue[] newData = new TValue[newSize]; TKey[] newKeys = new TKey[newSize]; data.CopyTo(newData, 0); keys.CopyTo(newKeys, 0); data = newData; keys = newKeys; } private void ValidateNonEmpty() { if (Count == 0) throw new IndexOutOfRangeException(); } }