結果
問題 |
No.8009 異なる数字の最大の範囲(勉強会用)
|
ユーザー |
![]() |
提出日時 | 2015-07-26 20:07:21 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,600 bytes |
コンパイル時間 | 875 ms |
コンパイル使用メモリ | 114,156 KB |
実行使用メモリ | 68,108 KB |
最終ジャッジ日時 | 2024-06-12 22:30:03 |
合計ジャッジ時間 | 10,819 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 21 TLE * 1 |
コンパイルメッセージ
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.Generic; using System.Linq; class Program { static string InputPattern = "Input4"; static List<string> GetInputList() { var WillReturn = new List<string>(); if (InputPattern == "Input1") { WillReturn.Add("5"); WillReturn.Add("1 2 3 1 2"); } else if (InputPattern == "Input2") { WillReturn.Add("5"); WillReturn.Add("1 2 3 4 5"); } else if (InputPattern == "Input3") { WillReturn.Add("5"); WillReturn.Add("1 1 1 1 1"); } else { string wkStr; while ((wkStr = Console.ReadLine()) != null) WillReturn.Add(wkStr); } return WillReturn; } static void Main() { List<string> InputList = GetInputList(); int[] AArr = InputList[1].Split(' ').Select(X => int.Parse(X)).ToArray(); int UB = AArr.GetUpperBound(0); int Answer = 0; int L = 0; for (int R = 0; R <= UB; R++) { int CurrVal = AArr[R]; //再登場の数値の場合は、左からその数値までRemoveしつつ、Lを移動 int wkInd = Array.FindIndex(AArr, L, R - L, X => X == CurrVal); if (wkInd >= 0) { L = wkInd + 1; //下限値枝切り int RestMaxCnt = UB - L + 1; if (RestMaxCnt <= Answer) break; } if (Answer < R - L + 1) Answer = R - L + 1; } Console.WriteLine(Answer); } }