結果
問題 |
No.8009 異なる数字の最大の範囲(勉強会用)
|
ユーザー |
![]() |
提出日時 | 2015-07-26 19:39:14 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
TLE
|
実行時間 | - |
コード長 | 1,644 bytes |
コンパイル時間 | 852 ms |
コンパイル使用メモリ | 115,080 KB |
実行使用メモリ | 39,020 KB |
最終ジャッジ日時 | 2024-06-12 22:29:41 |
合計ジャッジ時間 | 10,851 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge2 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
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; var wkList = new List<int>(); int L = 0; for (int R = 0; R <= UB; R++) { int CurrVal = AArr[R]; //再登場の数値の場合は、左からその数値までRemoveしつつ、Lを移動 while (wkList.Contains(CurrVal)) { wkList.RemoveAt(0); L++; //下限値枝切り int RestMaxCnt = UB - L + 1; if (RestMaxCnt <= Answer) break; } wkList.Add(CurrVal); if (Answer < wkList.Count) Answer = wkList.Count; } Console.WriteLine(Answer); } }