結果

問題 No.2649 [Cherry 6th Tune C] Anthem Flower
ユーザー kakel-sankakel-san
提出日時 2024-02-23 21:50:00
言語 C#
(.NET 8.0.203)
結果
AC  
実行時間 822 ms / 2,000 ms
コード長 1,693 bytes
コンパイル時間 8,171 ms
コンパイル使用メモリ 171,060 KB
実行使用メモリ 224,916 KB
最終ジャッジ日時 2024-09-29 06:14:14
合計ジャッジ時間 16,842 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 60 ms
30,976 KB
testcase_01 AC 498 ms
69,264 KB
testcase_02 AC 487 ms
69,392 KB
testcase_03 AC 506 ms
69,144 KB
testcase_04 AC 504 ms
69,264 KB
testcase_05 AC 821 ms
69,516 KB
testcase_06 AC 822 ms
69,144 KB
testcase_07 AC 118 ms
41,444 KB
testcase_08 AC 118 ms
41,344 KB
testcase_09 AC 84 ms
34,304 KB
testcase_10 AC 83 ms
34,304 KB
testcase_11 AC 60 ms
30,972 KB
testcase_12 AC 60 ms
30,976 KB
testcase_13 AC 102 ms
39,296 KB
testcase_14 AC 105 ms
39,936 KB
testcase_15 AC 104 ms
37,632 KB
testcase_16 AC 103 ms
39,164 KB
testcase_17 AC 106 ms
41,472 KB
testcase_18 AC 102 ms
36,708 KB
testcase_19 AC 102 ms
37,632 KB
testcase_20 AC 105 ms
40,832 KB
testcase_21 AC 105 ms
37,632 KB
testcase_22 AC 102 ms
39,552 KB
testcase_23 AC 103 ms
40,832 KB
testcase_24 AC 103 ms
41,088 KB
testcase_25 AC 101 ms
43,032 KB
testcase_26 AC 102 ms
40,960 KB
testcase_27 AC 101 ms
40,960 KB
testcase_28 AC 101 ms
40,704 KB
testcase_29 AC 99 ms
40,956 KB
testcase_30 AC 100 ms
40,960 KB
testcase_31 AC 97 ms
41,084 KB
testcase_32 AC 99 ms
40,832 KB
testcase_33 AC 101 ms
42,496 KB
testcase_34 AC 385 ms
224,916 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
  復元対象のプロジェクトを決定しています...
  /home/judge/data/code/main.csproj を復元しました (91 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/

ソースコード

diff #

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

class Program
{
    static int NN => int.Parse(ReadLine());
    static long[] NList => ReadLine().Split().Select(long.Parse).ToArray();
    public static void Main()
    {
        Solve();
    }
    static void Solve()
    {
        var t = NN;
        var ans = new long[t];
        for (var u = 0; u < t; ++u)
        {
            var s = ReadLine().Split();
            var n = s[0];
            var m = int.Parse(s[1]);
            var b0 = n.Select(i => i - '0').ToList();
            var b1 = b0.ToList();
            Increment(b1);
            if (b0[^1] % 2 == 0) Half(b0);
            else Half(b1);
            var b0m = 0L;
            for (var i = 0; i < b0.Count; ++i) b0m = (b0m * 10 + b0[i]) % m;
            var b1m = 0L;
            for (var i = 0; i < b1.Count; ++i) b1m = (b1m * 10 + b1[i]) % m;
            ans[u] = b0m * b1m % m;
        }
        WriteLine(string.Join("\n", ans));
    }
    static void Increment(List<int> b)
    {
        for (var i = b.Count - 1; i >= 0; --i)
        {
            b[i] = (b[i] + 1) % 10;
            if (b[i] != 0) break;
        }
        if (b[0] == 0) b.Insert(0, 1);
    }
    static void Half(List<int> b)
    {
        var take = 0;
        for (var i = 0; i < b.Count; ++i)
        {
            if ((b[i] + take * 10) % 2 == 1)
            {
                b[i] = (b[i] + take * 10) / 2;
                take = 1;
            }
            else
            {
                b[i] = (b[i] + take * 10) / 2;
                take = 0;
            }
        }
    }
}
0