結果
問題 |
No.2548 Problem Selection
|
ユーザー |
![]() |
提出日時 | 2023-11-25 20:08:21 |
言語 | C# (.NET 8.0.404) |
結果 |
AC
|
実行時間 | 115 ms / 2,000 ms |
コード長 | 925 bytes |
コンパイル時間 | 16,456 ms |
コンパイル使用メモリ | 168,640 KB |
実行使用メモリ | 184,472 KB |
最終ジャッジ日時 | 2024-09-26 11:11:59 |
合計ジャッジ時間 | 14,193 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 25 |
コンパイルメッセージ
復元対象のプロジェクトを決定しています... /home/judge/data/code/main.csproj を復元しました (106 ms)。 MSBuild のバージョン 17.9.6+a4ecab324 (.NET) main -> /home/judge/data/code/bin/Release/net8.0/main.dll main -> /home/judge/data/code/bin/Release/net8.0/publish/
ソースコード
using static System.Math; using System; public class Hello { static void Main() { string[] line = Console.ReadLine().Trim().Split(' '); var n = int.Parse(line[0]); var k = int.Parse(line[1]); line = Console.ReadLine().Trim().Split(' '); var a = Array.ConvertAll(line, long.Parse); getAns(n, k, a); } static void getAns(int n, int k, long[] a) { Array.Sort(a); var b = new long[n - 1]; for (int i = 0; i < n - 1; i++) { var t = a[i + 1] - a[i]; b[i] = t * t; } var s = 0L; for (int i = 0; i < k - 1; i++) s += b[i]; var c = new long[n]; c[0] = 0; for (int i = 1; i < n; i++) c[i] = c[i - 1] + b[i - 1]; var ans = long.MaxValue; for (int i = k - 1; i < n; i++) ans = Min(ans, c[i] - c[i - k + 1]); Console.WriteLine(ans); } }