結果
問題 |
No.390 最長の数列
|
ユーザー |
![]() |
提出日時 | 2021-04-30 11:24:24 |
言語 | C#(csc) (csc 3.9.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 954 bytes |
コンパイル時間 | 824 ms |
コンパイル使用メモリ | 110,720 KB |
実行使用メモリ | 36,696 KB |
最終ジャッジ日時 | 2024-07-18 09:43:37 |
合計ジャッジ時間 | 2,679 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 WA * 1 |
other | AC * 10 WA * 5 |
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc) Copyright (C) Microsoft Corporation. All rights reserved.
ソースコード
using static System.Math; using System; public class Hello { static void Main() { var n = int.Parse(Console.ReadLine().Trim()); string[] line = Console.ReadLine().Trim().Split(' '); var a = Array.ConvertAll(line, int.Parse); getAns(n, a); } static void getAns(int n, int[] a) { var ans = 0; Array.Sort(a); var amax = a[n - 1]; var b = new bool[amax + 1]; var used = new bool[amax + 1]; for (int i = 0; i < n; i++) b[a[i]] = true; for (int i = 0; i < n; i++) { if (used[a[i]]) continue; var p = a[i]; var count = 0; { while (p <= amax) { if (b[p]) { count++; used[p] = true; p += p; } else p += a[i]; } } ans = Max(ans, count); } Console.WriteLine(ans); } }