結果

問題 No.837 Noelちゃんと星々2
コンテスト
ユーザー kakel-san
提出日時 2026-05-06 19:12:11
言語 C#
(.NET 10.0.201)
コンパイル:
dotnet_c
実行:
/usr/bin/dotnet_wrap
結果
AC  
実行時間 61 ms / 2,000 ms
コード長 1,109 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 9,894 ms
コンパイル使用メモリ 173,284 KB
実行使用メモリ 199,736 KB
最終ジャッジ日時 2026-05-06 19:12:30
合計ジャッジ時間 12,847 ms
ジャッジサーバーID
(参考情報)
judge3_0 / judge1_0
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 4
other AC * 29
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.csproj を復元しました (91 ミリ秒)。
  main -> /home/judge/data/code/bin/Release/net10.0/main.dll
  main -> /home/judge/data/code/bin/Release/net10.0/publish/

ソースコード

diff #
raw source code

using System;
using static System.Console;
using System.Linq;
using System.Collections.Generic;

class Program
{
    static int NN => int.Parse(ReadLine());
    static int[] NList => ReadLine().Split().Select(int.Parse).ToArray();
    static int[][] NArr(long n) => Enumerable.Repeat(0, (int)n).Select(_ => NList).ToArray();
    public static void Main()
    {
        Solve();
    }
    static void Solve()
    {
        var n = NN;
        var y = NList;
        Array.Sort(y);
        WriteLine(Star(n, y));
    }
    static long Star(int n, int[] y)
    {
        if (y[0] == y[^1])
        {
            return 1;
        }
        var cum = new long[n + 1];
        for (var i = 0; i < n; ++i) cum[i + 1] = cum[i] + y[i];
        var ans = long.MaxValue;
        for (var sl = 1; sl < n; ++sl)
        {
            var fc = sl / 2;
            var sc = (n + sl) / 2;
            ans = Math.Min(ans, (long)y[fc] * fc - cum[fc] + cum[sl] - cum[fc] - (long)y[fc] * (sl - fc) + (long)y[sc] * (sc - sl) - cum[sc] + cum[sl] + cum[n] - cum[sc] - (long)y[sc] * (n - sc));
        }
        return ans;
    }
}
0